Vue学习笔记三:Computed 和 Watch 的使用方法详解

16 篇文章 1 订阅
一、计算属性 Computed
  • Computed 用来监控自己定义的变量,该变量不在 data 里面声明,直接在 computed 里面定义,然后就可以在页面上进行双向数据绑定展示出结果或者用其他处理;
  • Computed 比较适合对多个变量或者对象进行处理后返回一个结果值,也就是多个变量中的某一个值发生变化则我们监控的这个值也就发生变化;
  • Computed 计算属性基于响应式依赖进行缓存。如其中的任意一个值未发生变化,它调用的就是上一次计算缓存的数据,因此提高了程序的性能。而 methods 中每调用一次就会重新计算一次,为了进行不必要的资源消耗,选择用计算属性。
<template>
  <div>
    <input type="text" v-model="mytext">
    <ul>
      <li v-for="data in datalistcom" :key="data">
        {{ data }}
      </li>
    </ul>
  </div>
</template>
<script>
export default{
  name: 'TestComputed',
  data(){
    return{
      datalist:["aaa","bbb","ccc","ddd","aa","a","cc","dd"],
      mytext: ''
    }
  },
  computed:{
    datalistcom(){
      return this.datalist.filter(item=>item.indexOf(this.mytext)>-1)
    }
  }
}
</script>

结果是:
在这里插入图片描述
搜索之后得出的结果:
在这里插入图片描述

二、监听属性 Watch
  • Watch 主要用于监控 Vue 实例的变化,它监控的变量必须在 data 里面声明才可以,它可以监控一个变量,也可以是一个对象。
  • 计算属性 Computed 初始化的时候就可以被监听到并且计算,但 Watch 是发生改变的时候才会触发。
  • 当有一些数据需要随着其他数据变动而变动时,或者当需要在数据变化时执行异步或者开销较大的操作时,可以用 Watch。
<template>
  <div>
    <p>单价:<input type="text" v-model="price"></p>
    <p>数量:<input type="text" v-model="number"></p>
    <p>计算金额:{{sum}}</p>
  </div>
</template>
<script>
export default{
  name: 'TestWatch',
  data(){
    return{
      price: 100,
      number: 0,
      sum: 0
    }
  },
  watch:{
    // 监听的参数的名字要一致
    price(){
      console.log(this.price)
      if(this.price*this.number < 1000 && this.price*this.number > 0){
        this.sum = this.price*this.number
      }else{
        this.sum = this.price*this.number
      }
    },
    number(){
      console.log(this.price)
      if(this.price*this.number < 1000 && this.price*this.number > 0){
        this.sum = this.price*this.number
      }else{
        this.sum = this.price*this.number
      }
    }
  }
}
</script>

结果是:
在这里插入图片描述
计算结果:
在这里插入图片描述

三、Computed 与 Watch 的区别
  • 计算属性变量在 Computed 中定义,属性监听变量在 data 中定义。
  • 计算属性是声明式的描述一个值依赖了其他值,依赖的值改变后重新计算结果更新 DOM。属性监听的是定义的变量,当定义的值发生变化时,执行相对应的函数。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值