您现在的位置是:网站首页> 编程资料编程资料
Vue 中的 computed 和 watch 的区别详解_vue.js_
2023-05-24
431人已围观
简介 Vue 中的 computed 和 watch 的区别详解_vue.js_
computed
computed 看上去是方法,但是实际上是计算属性,它会根据你所依赖的数据动态显示新的计算结果。计算结果会被缓存,computed 的值在 getter 执行后是会缓存的,只有在它依赖的属性值改变之后,下一次获取 computed 的值时才会重新调用对应的 getter 来计算。
1)下面是一个比较经典简单的案例
{{fullName}}
注意
在 Vue 的 template 模板内({{}})是可以写一些简单的js表达式的很便利,如上直接计算 {{this.firstName + ' ' + this.lastName}},因为在模版中放入太多声明式的逻辑会让模板本身过重,尤其当在页面中使用大量复杂的逻辑表达式处理数据时,会对页面的可维护性造成很大的影响,而 computed 的设计初衷也正是用于解决此类问题。
应用场景
适用于重新计算比较费时不用重复数据计算的环境。所有 getter 和 setter 的 this 上下文自动地绑定为 Vue 实例。如果一个数据依赖于其他数据,那么把这个数据设计为 computed
watch
watcher 更像是一个 data 的数据监听回调,当依赖的 data 的数据变化,执行回调,在方法中会传入 newVal 和 oldVal。可以提供输入值无效,提供中间值 特场景。Vue 实例将会在实例化时调用 $watch(),遍历 watch 对象的每一个属性。如果你需要在某个数据变化时做一些事情,使用watch。
{{fullName}}
总结
- 1.如果一个数据依赖于其他数据,那么把这个数据设计为 computed
- 2.如果你需要在某个数据变化时做一些事情,使用 watch 来观察这个数据变化
到此这篇关于Vue 中的 computed 和 watch 的区别详解的文章就介绍到这了,更多相关Vue computed 和 watch 内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- 解决VuePress页面乱码问题_vue.js_
- JavaScript中执行上下文和执行栈_javascript技巧_
- vue中的公共方法调用方式_vue.js_
- Vue3初探之ref、reactive以及改变数组的值_vue.js_
- vue-devtools 打开源码位置实现过程_vue.js_
- js 实现Material UI点击涟漪效果示例_JavaScript_
- js 实现验证码输入框示例详解_JavaScript_
- react中代码块输出,代码高亮显示,带行号,能复制的问题_React_
- TypeScript 内置高级类型编程示例_JavaScript_
- vue Keep-alive组件缓存的简单使用代码_vue.js_
