详解vue中computed 和 watch的异同
一、computed和watch都可以观察页面的数据变化。当处理页面的数据变化时,我们有时候很容易滥用watch。而通常更好的办法是使用computed属性,而不是命令是的watch回调。
这里我直接引用vue官网的例子来说明:
html:
我们要实现第三个表单的值是第一个和第二个的拼接,并且在前俩表单数值变化时,第三个表单数值也在变化
js:用watch方法来实现
newVue({ el:'#myDiv', data:{ firstName:'Foo', lastName:'Bar', fullName:'FooBar' }, watch:{ firstName:function(val){ this.fullName=val+''+this.lastName }, lastName:function(val){ this.fullName=this.firstName+''+val } } })
js:利用computed来写
newVue({ el:"#myDiv", data:{ firstName:"Den", lastName:"wang", }, computed:{ fullName:function(){ returnthis.firstName+""+this.lastName; } } })
很容易看出computed在实现上边的效果时,是更简单的。
二、详解comouted计算属性。
在vue的模板内({{}})是可以写一些简单的js表达式的,很便利。但是如果在页面中使用大量或是复杂的表达式去处理数据,对页面的维护会有很大的影响。这个时候就需要用到computed计算属性来处理复杂的逻辑运算。
1.优点:
在数据未发生变化时,优先读取缓存。computed计算属性只有在相关的数据发生变化时才会改变要计算的属性,当相关数据没有变化是,它会读取缓存。而不必想motheds方法和watch方法是的每次都去执行函数。
2.setter和getter方法:(注意在vue中书写时用set和get)
- setter方法在设置值是触发。
- getter方法在获取值时触发。
computed:{ fullName:{ //这里用了es6书写方法 set(){ alert("set"); }, get(){ alert("get"); returnthis.firstName+""+this.lastName; }, } }
三、watch方法
虽然计算属性在大多数情况下是非常适合的,但是在有些情况下我们需要自定义一个watcher,在数据变化时来执行异步操作,这时watch是非常有用的。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。