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"

}

}

对比代码:

温馨提示:答案为网友推荐,仅供参考
第1个回答  2017-08-06
一、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