VUE computed 计算属性本来的样子

计算属性的特点

  • 计算属性可以对计算属性依赖的属性进行监视;
  • 计算属性基于相关依赖进行更新,只有相关依赖发生改变时才更新;
  • 基于上一条,因此计算属性有缓存,只要相关依赖不发生改变,多次访问计算属性return的值是之前缓存的值,不会多次执行;

计算属性的完整写法

常用写法

    data () {
        return {
            firstName: 'natsume',
            lastName: 'takashi'
        }
    },
    computed: {
        fullName () {
            return this.firstName + ' ' + this.lastName
        },
    },

完整写法:

    computed: {
        fullName: {
            set: function (newVal) {
                this.firstName = newVal
            },
            get: function () {
                return this.firstName + ' ' + this.lastName
            }
        }
    },

正常情况下,不能给计算属性赋值,既计算属性为只读属性,若使用完整写法,在计算属性中修改计算属性相关依赖的值,计算属性也会重新计算,但是不可在计算属性的set方法中直接给计算属性赋值,会造成死循环,堆栈溢出报错;

若省略计算属性的set可简写为:

    computed: {
        fullName: {
            get: function () {
                return this.firstName + ' ' + this.lastName
            }
        }
    },

因为大多数情况下都不需要设置set,因此可以进一步简写:

    computed: {
        fullName: function () {
            return this.firstName + ' ' + this.lastName
        }
    },

采用ES6的写法既是常用写法:

    computed: {
        fullName () {
            return this.firstName + ' ' + this.lastName
        }
    },
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值