> 文章列表 > 学习笔记|Vue入门笔记-计算属性详细学习笔记

学习笔记|Vue入门笔记-计算属性详细学习笔记

学习笔记|Vue入门笔记-计算属性详细学习笔记

1、引出问题

我们都知道在Vue构造函数的参数对象中有一个【data】属性,该属性值是一个对象,该对象是对数据的代理,是一个键值对并且时刻与页面表现是一致的,但是这里面只能是简单的键值对,不能拥有业务逻辑,并且由于【data】中的属性属于同一个生命周期,所以如果我们需要某一个属性是依赖于另外一个属性时,在【data】中是做不到的,于是Vue为我们提供了【计算属性】

学习笔记|Vue入门笔记-计算属性详细学习笔记

2、计算属性

2.1 概述

计算属性归根结底也是属性,它也是跟表现层是时刻同步的,虽然我们可以在插值中对数据进行各种处理,但是插值中的表达式处理毕竟只能用于简单的运算,不能拥有太多的业务逻辑。

<body><div id="app"><h1>{{name.toUpperCase()}}</h1><!-- <h1>BLUE</h1> --></div>
</body><script>let vm = new Vue({el: "#app",data: {name: 'blue'}})
</script>

上面代码是熟悉的在插值中使用表达式,但是这里面我们不能写入业务代码。

2.2 计算属性语法

在构造函数的参数对象中有一个【computed】属性,该属性就是用于定义计算属性的,该对象中的【键】也就是我们的计算属性,与【data】不同的是,计算属性的键值是一个【拥有返回值的函数】,该函数中可以访问到【data】中的所有属性。

<body><div id="app"><h1>{{rs}}</h1><!-- <h1>BLUE LOVE PINK</h1> --></div>
</body><script>let vm = new Vue({el: "#app",data: {hs: 'BLUE',wf: "PINK"},computed: {rs:function(){return `${this.hs} LOVE ${this.wf}`}}})
</script>

上面代码属性【rs】是定义的一个计算属性,该属性值是通过【data】中的两个属性值计算得到,返回一个拼接的字符串并且当【data】中的相关值变化之后,【rs】属性都会进行重新计算。

可能刚开始对计算属性会有些疑惑,比如上面的例子我把代码写成下面这样子也是可以的

<body><div id="app"><h1>{{hs}} LOVE {{wf}}</h1><!-- <h1>BLUE LOVE PINK</h1> --></div>
</body><script>let vm = new Vue({el: "#app",data: {hs: 'BLUE',wf: "PINK"}})
</script>

上面的代码运行效果和我们使用计算属性的效果是一样的,但是这样的写法只适用于简单的处理,【计算属性可以处理更复杂的业务逻辑】,比如我们根据【data】中的一个属性值进行数据请求用于构建一个属性,我们就必须使用计算属性了。

【注意!!】计算属性虽然是一个方法,但是在Vue内部会被翻译成一个属性,我们可以使用实例【vm.rs】访问到数据的。

2.3 计算属性和过滤器的比较

如果用于对【data】中【单个】属性的【简单】处理,推荐使用过滤器,但是如果一个值使用了【data】中至少2个值或者对一个值进行复杂处理,那么就推荐使用计算属性了。

<body><div id="app"><h1>{{hs | lover}}</h1><!-- <h1>BLUE LOVE PINK</h1> --></div>
</body><script>let vm = new Vue({el: "#app",data: {hs: 'BLUE',},filters: {lover(value){return `${value} LOVE PINK`}}})
</script>

上面代码就使用了一个【data】属性值做简单的处理,所以使用过滤器,而且也发现了过滤字符串“LOVE PINK”是不可变的。

学习笔记|Vue入门笔记-计算属性详细学习笔记

2.4 计算属性和Methods的比较

计算属性就是为了定属性的时候处理复杂的业务逻辑,而且在插值中我们可以使用表达式,那么我们是否可以通过使用在插值中调用一个有返回值的函数呢?它和计算属性又有什么区别呢?

<body><div id="app"><h1>{{rs}}</h1><!-- <h1>EULB</h1> --></div>
</body><script>let vm = new Vue({el: "#app",data: {name: 'BLUE',},computed: {rs: function () {return [...this.name].reverse().join('');}}})
</script>

上面代码将数据进行反向处理,当我们改变name的值的时候,计算属性【rs】会跟着改变。下面我们将它改成一个方法结合插值表达式进行处理,看看区别。

<body><div id="app"><h1>{{ rs() }}</h1><!-- <h1>EULB</h1> --></div>
</body><script>let vm = new Vue({el: "#app",data: {name: 'BLUE',},methods: {rs() {return [...this.name].reverse().join('');}}})
</script>

上面代码将计算属性改成了一个方法结合插值表达式,发现效果和计算属性没差别,改变name的值的时候页面也刷新了。那是不是这两者就真的没区别呢,答案当然是否定的,如果没有区别干嘛还有计算属性的存在。

2.5 计算属性和Watch的比较

我们发现计算属性会监听依赖,如果依赖发生变化则会从新计算属性,那么【监听器】也有这么一个功能,那么我们应该在什么时候使用【计算属性】,什么时候使用【监听器】呢?

<body><div id="app"><h1>{{fullName}}</h1></div>
</body><script>let vm = new Vue({el: "#app",data: {firstName: 'Jum',lastName: 'Blue',fullName: 'Jack Blue'},watch: {firstName: function (val) {this.fullName = val + ' ' + this.lastName},lastName: function (val) {this.fullName = this.firstName + ' ' + val}}})
</script>

上面代码中我们监听firstNamelastName用于构建fullName,效果很好,当firstName和lastName任意一个值改变的时候fullName都会随之改变。下面我们看一下计算属性的写法

<body><div id="app"><h1>{{fullName}}</h1><!-- <h1>Jack Blue</h1> --></div>
</body><script>let vm = new Vue({el: "#app",data: {firstName: 'Jum',lastName: 'Blue',},computed: {fullName() {return this.firstName + ' ' + this.lastName}}})
</script>

上面代码使用计算属性的方式进行了改造,fullName 依赖 firstName和 lastName 两个属性,当这两个属性任意一个发生变化,fullname都会重新进行计算。但是计算属性是不是简洁了很多呢!

总结:当一个属性需要依赖多个【data】中的属性时,建议使用计算属性,如果我们不是对属性进行操作,只是单纯的依据【data】中的某个值变化后做一些【非属性操作】时或者是在数据变化响应时,【执行异步操作或开销较大的操作】(比如:将变化后的值存入数据库,而不是改变其他属性)就使用Watch。

2.6 计算属性的setter

上面我们是使用的计算属性都是用于对计算属性的取值,计算属性默认页只给了【getter】,但是在需要的时候我们可以人为的添加【setter】


<body><div id="app"><h1>{{fullName}}</h1><!-- <h1>Jack Blue</h1> --></div>
</body><script>let vm = new Vue({el: "#app",data: {firstName: 'Jum',lastName: 'Blue',},computed: {fullName: {//getterget() {return this.firstName + ' ' + this.lastName},//setterset(newValue) {var names = newValue.split(' ')this.firstName = names[0]this.lastName = names[names.length - 1]}}}})
</script>

上面代码定义了计算属性的一个setter,注意当需要定义setter的时候语法上面是有区别的。

3、参考文献

  1. ECMAScript 6 入门

  1. 技能树-Vue入门

  1. Vue中文网快速上手中文文档