Vue 计算属性 computed

当你的项目中有需要计算的,并且是需要依赖其他值动态计算的值,那么就到了使用计算属性的时候!

比如计算一个加法

<script>    
    computed: {
      sum: function (){
        return this.num1 + this.num2
      }
    },
    data() {
        return {
            num1: 1,
            num2: 2
        }
    }
</script>


<template>
    <div>{{ sum }}</div>
</template>

首先是computed的语法:

1.在computed中声明的值是不能和data中的值命名冲突的,因为使用是都是 this.‘key’

2.computed的写法就是 'key': function(){} ,他的值就是这个函数的返回值,并且在这个函数中也是可以调用this实例

此时我们修改了num1 或 num2 ,sum会检测到数据变化,重新计算给sum赋值

// 在template中
<button @click="this.num1++">{{ num1 }}</button>
<button @click="this.num2++">{{ num2 }}</button>
<div>{{ sum }}</div>    

计算属性中,默认写的方法就是getter并且只有这一个函数,有需要的话可以将属性写成对象,分别写入getter 和 setter

<script>    
    computed: {
      double: {
        get:function() {
            return this.num * 2
        }
        set: function(value) {
            this.num = value / 2
        }
      }
    },
    data() {
        return {
            num: 10
        }
    }
</script>


<template>
    <input v-model="double">
    <input v-model="num">
</template>

这时修改 num 触发 get方法,修改double触发set方法

:computed中如果写箭头函数是取不到this的,涉及到箭头函数this指向的问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值