【watch、computed和methods的区别】

computed用于计算属性,依赖数据变化时自动更新,有缓存机制;watch是对值的监听,变化时执行回调,可设置立即触发;methods仅包含可调用的函数,不处理数据。computed适合复杂但不频繁计算的数据,watch适合数据变化时需执行特定操作的情况。
摘要由CSDN通过智能技术生成

功能不同

  1. computed是计算属性,会根据依赖数据的变化动态的显示新的计算结果
  2. watch是监听一个值的变化,执行相应的回调,在方法中传入新值和老值
  3. methods是挂载在对象上的函数,不处理数据逻辑,只提供可手动调用的函数

是否调用缓存不同

  1. computed的计算结果会被缓存,如果依赖的属性值没有变化,会从缓存中取,只有当依赖的属性值发生改变时才会重新调用对应的getter计算
  2. watch在每次监听的值发生变化时,都会执行回调

默认监听不同

  1. computed默认在第一次加载时就开始监听
  2. watch默认第一次加载不做监听,如果想要第一次加载就做监听,主要添加immediate的属性为ture

是否调用return

  1. computed中的函数必须要用return返回
  2. watch中的函数不是必须使用return

使用场景不同

  1. computed:由于vue的{{}}中也可以写一下简单的js计算,但如果在页面中使用太多的逻辑表达去处理数据时,会影响页面的可维护性,适用于比较费时但不需要重复计算的环境,如果一个数据依赖于其他的属性,可以把这个数据设计成computed
  2. watch:在某个数据变化时需要执行一些操作,使用watch来观察变化
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值