Vue计算属性computed的全面解析

前言

一直以来对computed这个计算属性都只停在一个大概的认知中,最近特意仔细研读相关资料,亲测后逐渐了解了其特性。

正文

computed

1.watch擅长处理的场景:一个数据影响多个数据

2.computed擅长处理的场景:一个数据受多个数据影响

 特点:

1.初始化/依赖属性(即data的return返回对象的属性)改变时执行(前提是在页面调用计算属性)

2.在计算属性函数执行后会缓存返回值

3.计算属性返回值就是计算属性的值

4.当依赖属性未改变时调用计算属性则直接返回缓存的值

注意:computed属性名不可与data的return返回对象的属性重名,否则会报错。

用处:需要依赖别的属性来动态获得值的时候或大量重复计算时可以使用 computed

例:

    data() {
      return {
        msg:''
      }
    },
    computed: {
      test: function(){//test为计算属性,调用时和调用属性一样调用test即可
        console.log('执行了!')
        return 'http://' + this.msg//msg是依赖属性,改变时会执行test函数
      }
    }

 

需要特别注意的是依赖属性为数组时,会自动把数组转化为字符串;为对象时,会变为[object Object]

上面的写法中,计算属性不能被修改,如果修改了,就会报下面的错误:

上面错误的原因是computed默认只有getter,所以当你需要修改你所设置的计算属性时必须为它提供一个setter,如下例:

初始化/当计算属性test依赖的响应式属性msg变化时,会执行get(),当计算属性test变化时会执行set(),且set中的参数就是计算属性test的最新值

下例中set()中的赋值是在计算属性test改变时赋值给依赖属性msg,这样两值改变另一方都会改变

    data() {
      return {
        msg:'12345'
      }
    },
    computed: {
      test: {
        get:function () {
          console.log('当依赖的响应式属性(msg)被修改时执行!')
          return this.msg.split('').reverse().join(''); //这里的返回值就是计算属性的最新值,可在此处修改计算属性的值
        },
        set:function (val) {//val就是计算属性的最新属性值
          console.log('当计算属性test被修改时执行!')
          this.msg = val;
          return val;
        }
      }
    }
posted @ 2019-08-05 17:07  喜欢安静的时空  阅读(1732)  评论(0编辑  收藏  举报