zoukankan      html  css  js  c++  java
  • vue中的computed和watch区别

    在vue.js官方文档中看到computed和watch获取全名的一个例子:

     1 var var vm = new Vue({
     2   el: '#demo',
     3   data: {
     4     firstName: 'Foo',
     5     lastName: 'Bar',
     6     fullName: 'Foo Bar'
     7   },
     8   watch: {
     9     firstName: function (val) {
    10       this.fullName = val + ' ' + this.lastName
    11     },
    12     lastName: function (val) {
    13       this.fullName = this.firstName + ' ' + val
    14     }
    15   }
    16 })
     1 var var vm = new Vue({
     2   el: '#demo',
     3   data: {
     4     firstName: 'Foo',
     5     lastName: 'Bar'
     6   },
     7   computed: {
     8     fullName: function () {
     9       return this.firstName + ' ' + this.lastName
    10     }
    11   }
    12 })

    计算属性顾名思义就是通过其他变量计算得来的另一个属性,fullName在它所依赖firstName,lastName这两个变量变化时重新计算自己的值。

    另外,计算属性具有缓存。计算属性是基于它们的依赖进行缓存的。计算属性只有在它的相关依赖发生改变时才会重新求值。这就意味着只要 lastName和firstName都没有发生改变,多次访问 fullName计算属性会立即返回之前的计算结果,而不必再次执行函数。

    而观察watch是观察一个特定的值,当该值变化时执行特定的函数。例如分页组件中,我们可以检测页码执行获取数据的函数。

  • 相关阅读:
    48. 旋转图像(顺时针)
    560. 和为K的子数组
    75. 颜色分类(三指针移动||计数排序)
    670. 最大交换
    常见端口号汇总
    springboot解决跨域问题跨域
    jad使用
    tomcat9:解决tomcat catalina log和localhost log中文乱码
    JUC:阻塞队列
    JUC:读写锁
  • 原文地址:https://www.cnblogs.com/lvshaonan/p/8655466.html
Copyright © 2011-2022 走看看