1.vue计算属性computed
1.插值语法特点
可以在{{}}中编写合法的JavaScript表达式
2.在插值语法中编写JavaScript表达式缺点
2.1没有代码提示
2.2语句过于复杂不利于我们维护
3.如何解决?
对于任何复杂逻辑,你都应当使用计算属性
【注意点】
- 虽然在定义计算属性的时候是通过一个函数返回的数据,但是在使用计算属性的时候不能在计算属性名称后面加上(),这是因为它是一个
属性
不是一个函数
(方法),- computed的属性名不应和data中的一样,否则computed与data数据通名的属性将失效
1.计算属性和函数
- 通过计算属性我们能拿到处理后的数据, 但是通过函数我们也能拿到处理后的数据
- 那么计算属性和函数有什么区别呢?
- 2.1 函数"不会"将计算的结果缓存起来, 每一次访问都会重新求值
- 2.2 计算属性"会"将计算的结果缓存起来, 只要数据没有发生变化, 就不会重新求值
3.计算属性应用场景
计算属性:比较适合用于计算不会频繁发生变化的的数据
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Vue-Directives</title> <script src="vue.js"></script> </head> <body> <div id="app"> <p>{{msg1}}</p> </div> <script> let vue1=new Vue( { el:"#app", data:{ msg:"华中师范大学信息管理学院" }, method:{}, computed:{ msg1:function (){ return this.msg.split("").reverse().join(""); } } } ) </script> </body> </html>
2.vue-filter
过滤器
1.什么是过滤器?
过滤器和函数和计算属性一样都是用来处理数据的
但是过滤器一般用于格式化插入的文本数据
2.如何自定义全局过滤器
Vue.filter("过滤器名称", 过滤器处理函数):
3.如何使用全局过滤器
{{msg | 过滤器名称}}
:value="msg | 过滤器名称"
4.过滤器注意点
4.1只能在插值语法和v-bind中使用
4.2过滤器可以连续使用
如何自定义一个全局过滤器?
通过Vue.filter();
filter方法接收两个参数——第一个参数: 过滤器名称;第二个参数: 处理数据的函数
注意点: 默认情况下处理数据的函数接收一个参数, 就是当前要被处理的数据
2.1全局过滤器
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Vue-filter</title> <script src="vue.js"></script> </head> <body> <div id="app"> <p>{{msg|filter1}}</p> </div> <script> Vue.filter("filter1",function (value){ value=value.replace(/事件/g,"时间") return value; }) let vue=new Vue({ el:"#app", data: { msg: "事件花在哪里,收获就在哪里" } }) </script> </body> </html>
2.2 局部过滤器
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Vue-filter</title> <script src="vue.js"></script> </head> <body> <div id="app"> <p>{{msg|filter1}}</p> <p>{{msg|filter2}}</p> </div> <script> // Vue.filter("filter1",function (value){ // value=value.replace(/事件/g,"时间") // return value; // }) let vue=new Vue({ el:"#app", data: { msg: "事件花在哪里,收获就在哪里" }, filters:{ "filter1":function(value){ value=value.replace(/事件/g,"时间1") return value; }, "filter2":function(value){ value=value.replace(/事件/g,"时间2") return value; } } }) </script> </body> </html>
时间过滤器
练习
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Vue-filter</title> <script src="vue.js"></script> </head> <body> <div id="app"> <p>{{time|dateFormat("YYYY-MM-DD")}}</p> </div> <script> //时间过滤器 Vue.filter("dateFormat",function (value,fmtStr){ let time=new Date(value); let year=time.getFullYear()+""; let month=time.getMonth()+1+""; let day=time.getDay()+""; let hours=time.getHours()+""; let minutes=time.getMinutes()+""; let seconds=time.getSeconds()+""; if (fmtStr==="YYYY-MM-DD"&&fmtStr){ return `${year}-${month.padStart(2,"0")}-${day.padStart(2,"0")}` } return `${year}-${month.padStart(2,"0")}-${day.padStart(2,"0")} ${hours.padStart(2,"0")}:${minutes.padStart(2,"0")}:${seconds.padStart(2,"0")}` }) let vue=new Vue({ el:"#app", data: { msg: "时间花在哪里,收获就在哪里", time:Date.now() }, }) </script> </body> </html>