vue2 中 computed 和 watch 的异同

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue2 中 computed 和 watch 的异同相关的知识,希望对你有一定的参考价值。

他们回答的他复杂了,小白根本看不懂。

首先两者都是在元素变化后才执行函数,区别在于

1.computed:通过其他元素构造新的元素,当其他元素变化时触发computed;当进入页面时加载dom时自动执行

例如:

com:function()b+c 当b或者c变化时,执行com函数;

使用场景(多对一):

computed=a+b+c;当其它任意元素发生变化时都可以触发computed重新构造给com赋值;

computed:

com:function()

return this.a+this.b+this.c

2.watch:就是观察本身,当本身值变化时触发watch;

例如:

wat:function(data) ...

当自身变化时执行wat函数;

使用场景(一对多):

watch元素发生变化时,我们可以在函数里分别重新定义其它元素;

例如

watch:

wat:function(data)

this.a=data+1;

this.b=data*2;

this.c="hello"

对比代码:

参考技术A 一、computed 和 watch 都可以观察页面的数据变化。当处理页面的数据变化时,我们有时候很容易滥用watch。 而通常更好的办法是使用computed属性,而不是命令是的watch回调。
这里我直接引用vue官网的例子来说明:
html:
我们要实现 第三个表单的值 是第一个和第二个的拼接,并且在前俩表单数值变化时,第三个表单数值也在变化
<div id="myDiv">
<input type="text" v-model="firstName">
<input type="text" v-model="lastName">
<input type="text" v-model="fullName">
</div>1234512345

js: 用watch方法来实现
new Vue(
el: '#myDiv',
data:
firstName: 'Foo',
lastName: 'Bar',
fullName: 'Foo Bar'
,
watch:
firstName: function (val)
this.fullName = val + ' ' + this.lastName
,
lastName: function (val)
this.fullName = this.firstName + ' ' + val

Vue中watch和computed的区别和应用场景

watch中的函数是不需要调用的,computed内部的函数调用的时候不需要加()。Watch是属性监听,监听属性的变化;computed是计算属性,通过属性计算而得来的属性。watch需要在数据变化时执行异步或开销较大的操作时使用。computed 属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算。主要当作属性来使用。

watch需要在数据变化时执行异步或开销较大的操作时使用

对于任何复杂逻辑或一个数据属性在它所依赖的属性发生变化时,也要发生变化,这种情况下,我们最好使用计算属性computed。

Computed:属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算。主要当作属性来使用;computed中的函数必须用return返回最终的结果。当computed中的函数所依赖的属性如果没有发生改变的时候,那么调用当前函数的时候结果会从缓存中读取。

Watch:一个对象,键是需要观察的表达式,值是对应回调函数。主要用来监听某些特定数据的变化,从而进行某些具体的业务逻辑操作。

Computed:当一个属性受多个属性影响的时候就需要用到computed。最典型的例子:购物车商品结算的时候。

Watch:当一条数据影响多条数据的时候就需要用watch搜索数据。

以上是关于vue2 中 computed 和 watch 的异同的主要内容,如果未能解决你的问题,请参考以下文章

vue2.0中的watch和计算属性computed

Vue2.0学习—watch和computed对比(三十七)

vue3中的computed和watch

vue2计算属性(computed)与侦听器(watch)详解

vue2

vue2中computed原理