Computed 、 Methods、Watchers

来源:互联网 发布:广州祺曜互娱 知乎 编辑:程序博客网 时间:2024/06/06 07:22
computed: {  // a computed getter  reversedMessage: function () {    // `this` points to the vm instance    return this.message.split('').reverse().join('')  }}methods: {  reversedMessage: function () {    return this.message.split('').reverse().join('')  }}

我们可以定义为一个 method 或一个计算属性。对于最终的结果,两种方式确实是相同的。然而,不同的是计算属性是基于它们的依赖进行缓存的。计算属性只有在它的相关依赖发生改变时才会重新求值。这就意味着只要 message 还没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。
这也同样意味着下面的计算属性将不再更新,因为 Date.now() 不是响应式依赖:

computed: {  now: function () {    return Date.now()  }}

相比而言,只要发生重新渲染,method 调用总会执行该函数。
我们为什么需要缓存?假设我们有一个性能开销比较大的的计算属性 A ,它需要遍历一个极大的数组和做大量的计算。然后我们可能有其他的计算属性依赖于 A 。如果没有缓存,我们将不可避免的多次执行 A 的 getter!如果你不希望有缓存,请用 method 替代。

Vue 确实提供了一种更通用的方式来观察和响应 Vue 实例上的数据变动:watch 属性。然而,通常更好的想法是使用 computed 属性而不是命令式的 watch 回调。但是当你想要在数据变化响应时,执行异步操作或开销较大的操作,就得选用命令式的 watch 回调。

原创粉丝点击