计算属性介绍
表达式是非常便利的,但是它们实际上只用于简单的运算。在模板中放入太多的逻辑会让模板过重且难以维护,所以引入了计算属性computed,将复杂的逻辑放入计算中进行处理,同时computed有缓存功能,防止复杂计算逻辑多次调用引起的性能问题。
computed原理介绍
- computed的属性reversedMessage在data中会有一个对我们不可见的cacheReversedMessage属性对应
- cacheReversedMessage的值是根据其绑定的data中的message来决定的
- 获取reversedMessage会返回cacheReversedMessage的值
- message更新之后会立马调用reversedMessage的get方法去给cacheReversedMessage赋值(无论reversedMessage在dom中是否使用)
- cacheReversedMessage的值发生变化时,相应的dom也会发生变化
注意:computed中的属性和data中的属性名字不能相同,一个属性要么在data里;要么在computed里,computed里的属性要跟data中的配合使用,当data属性发生变化时才会调用get方法更新reversedMessage的值,否则get方法即使返回一个随机数,reversedMessage的值也不会变
<div id="example">
<p>Original message: "{{ message }}"</p>
<p>Computed reversed message: "{{ reversedMessage }}"</p>
</div>
var vm = new Vue({
el: '#example',
data: {
message: 'Hello'
},
computed: {
// a computed getter
reversedMessage: function () {
// `this` points to the vm instance
return this.message.split('').reverse().join('')
}
}
})
#注意:只有当计算方法里面对应的 message 发生变化时,方法才会重新被调用reversedMessage的值才会随之更新,否则一直是缓存的值
为属性设置一个set方法
如果属性名对应一个方法 那么其为获取方法,如果想同时设置一个设置方法,那么代码如下:
当改变fullName的值的时候会立即调用set方法
computed: {
fullName: {
// getter
get: function () {
return this.firstName + ' ' + this.lastName
},
// setter
set: function (newValue) {
var names = newValue.split(' ')
this.firstName = names[0]
this.lastName = names[names.length - 1]
}
}
}