vue 计算属性

计算属性 computed

  对于复杂逻辑的计算结果,我们可以使用 计算属性

  例子

<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: {
    // 计算属性的 getter
    reversedMessage: function () {
      // `this` 指向 vm 实例
      return this.message.split('').reverse().join('')
    }
  }
})


// 结果:
// Original message: "Hello"
// Computed reversed message: "olleH"

这里我们声明了一个计算属性 reverseMessage 我们提供的函数将用作property vm.reversedMessage 的 getter 函数:

 

console.log(vm.reversedMessage) // => 'olleH'
vm.message = 'Goodbye'
console.log(vm.reversedMessage) // => 'eybdooG'

打开浏览器,在页面中修改 vm 。 vm.reversedMessage 的值始终取决于 vm.message 的值。

你可以像绑定普通函数 property 一样在模板中绑定计算属性。Vue 知道 vm.reversedMessage 依赖于 vm.message,因此当 vm.message 发生改变时,所有依赖 vm.reversedMessage 的绑定也会更新。而且最妙的是我们已经以声明的方式创建了这种依赖关系。

posted on 2022-03-07 15:17  zhishiyv  阅读(164)  评论(0编辑  收藏  举报

导航