vue计算属性和watch的区别
0 条评论vue计算属性和watch的区别
computed
使用场景:适用于重新计算比较费时不用重复数据计算的环境。所有 getter
和 setter
的 this
上下文自动地绑定为 Vue
实例。如果一个数据依赖于其他数据,那么把这个数据设计为computed
计算属性 computed
是基于data
中数据进行处理的,data
数据变化,他也跟着变化
当data
中数据没有发生改变时,我们调用computed
中函数n
次,只会进行缓存(执行一次)
每个计算属性都包含两个set
、get
属性
watch
使用场景:数据变化时执行异步或开销较大的操作,可以随时修改状态的变化watch
:类似于监听机制+事件机制。
在大部分情况下我们都会使用computed
,但如果要在数据变化的同时进行异步操作或者是比较大的开销,那么watch
为最佳选择。watch
为一个对象,键是需要观察的表达式,值是对应回调函数。值也可以是方法名,或者包含选项的对象。watcher
更像是一个 data
的数据监听回调,当依赖的 data
的数据变化,执行回调,在方法中会传入 newVal
和 oldVal
。可以提供输入值无效,提供中间值 特场景。Vue
实例将会在实例化时调用 $watch()
,遍历 watch
对象的每一个属性。如果你需要在某个数据变化时做一些事情,使用watch
。
示例代码
1 | <template> |
总结
如果一个数据依赖于其他数据,那么把这个数据设计为computed的
如果你需要在某个数据变化时做一些事情,使用watch来观察这个数据变化
本文转载自
百川的博客
,原文地址:https://www.hellolbc.me/archives/162/
- 本文链接:https://xuehuayu.cn/article/7455.html
- 版权声明:① 标为原创的文章为博主原创,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接。② 标为转载的文章来自网络,已标明出处,侵删。