发布网友 发布时间:2022-04-21 08:56
共3个回答
懂视网 时间:2022-04-25 18:48
以Vue为例,其watch和computed的区别如下:
1、computed支持缓存,只有依赖数据发生改变,才会重新进行计算;而watch不支持缓存,数据变,直接会触发相应的操作。
2、computed不支持异步,当computed内有异步操作时无效,无法监听数据的变化;而watch支持异步。
3、computed属性值会默认走缓存,计算属性是基于它们的响应式依赖进行缓存的,也就是基于data中声明过或者父组件传递的props中的数据通过计算得到的值;而watch监听的函数接收两个参数,第一个参数是最新的值,第二个参数是输入之前的值。
4、如果一个属性是由其它属性计算而来的,这个属性依赖其它属性,是一个多对一或者一对一,一般用computed;而当一个属性发生变化时,需要执行对应的操作;一对多一般用watch。
5、如果computed属性属性值是函数,那么默认会走get方法;函数的返回值就是属性的属性值;在computed中的,属性都有一个get和一个set方法,当数据变化时,调用set方法。而watch监听数据必须是data中声明过或者父组件传递过来的props中的数据,当数据变化时,触发其它操作,函数有两个参数。
热心网友 时间:2022-04-25 15:56
他们回答的他复杂了,小白根本看不懂。
首先两者都是在元素变化后才执行函数,区别在于
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"
}
}
对比代码:
热心网友 时间:2022-04-25 17:14
一、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