0
点赞
收藏
分享

微信扫一扫

Vue.js 学习4 计算属性

要解决的问题:

<div id="example">
{{ message.split('').reverse().join('') }}
</div>

模板内的表达式非常便利,但只用于简单的运算。在模板里放入太多的逻辑会让模板过于过重难以维护。
计算属性就是要简化模板里的逻辑。

1.基础例子

<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('')
}
}
})

2.计算缓存 vs Methods

计算属性只有在它的相关依赖发生改变时才会重新求值。
计算属性会使用缓存。而Methods不会。

3.Computed属性 vs Watched属性

一些数据需要随着其它数据变动而变动时,很容易滥用watch。
watched代码:

var vm = new Vue({
el: '#demo',
data: {
firstName: 'Foo',
lastName: 'Bar',
fullName: 'Foo Bar'
},
watch: {
firstName: function (val) {
this.fullName = val + ' ' + this.lastName
},
lastName: function (val) {
this.fullName = this.firstName + ' ' + val
}
}
})

使用computed属性:

var vm = new Vue({
el: '#demo',
data: {
firstName: 'Foo',
lastName: 'Bar'
},
computed: {
fullName: function () {
return this.firstName + ' ' + this.lastName
}
}
})

4.setter

计算属性默认只有getter,但也可以在需要的时候提供setter

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]
}
}
}

5.观察watchers


举报

相关推荐

0 条评论