欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue计算属性和侦听器

程序员文章站 2023-02-04 08:16:09
(1)计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的。在模板中放入太多的逻辑会让模板过重且难以维护: {{ message.split('').reverse().join('') }} 将上述例子改成: Original message: "{{ message }}" Co ......

(1)计算属性
模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的。在模板中放入太多的逻辑会让模板过重且难以维护:


{{ message.split('').reverse().join('') }}

将上述例子改成:

original message: "{{ message }}"


computed reversed message: "{{ reversedmessage }}"


var vm = new vue({
el: '#example',
data: {
message: 'hello'
},
computed: {
// 计算属性的 getter
reversedmessage: function () {
// this 指向 vm 实例
return this.message.split('').reverse().join('')
}
}
})
你可以像绑定普通属性一样在模板中绑定计算属性。vue 知道 vm.reversedmessage 依赖于 vm.message,因此当 vm.message 发生改变时,所有依赖 vm.reversedmessage 的绑定也会更新。而且最妙的是我们已经以声明的方式创建了这种依赖关系:计算属性的 getter 函数是没有副作用 (side effect) 的,这使它更易于测试和理解。
(2)计算属性缓存vs方法
我们可以将同一函数定义为一个方法而不是一个计算属性。两种方式的最终结果确实是完全相同的。然而,不同的是计算属性是基于它们的响应式依赖进行缓存的。只在相关响应式依赖发生改变时它们才会重新求值。这就意味着只要 message 还没有发生改变,多次访问 reversedmessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。
(3)计算属性 vs 侦听属性
侦听属性:当数据变化时调用的函数。

{{ fullname }}

使用侦听属性:
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
}
}
})
使用计算数属性:
var vm = new vue({
el: '#demo',
data: {
firstname: 'foo',
lastname: 'bar'
},
computed: {
fullname: function () {
return this.firstname + ' ' + this.lastname
}
}
})
(4)计算属性默认只有 getter ,不过在需要时你也可以提供一个 setter 。