vue2 中 computed 和 watch 的异同?
来源:互联网 发布:香港 收音机软件 推荐 编辑:程序博客网 时间:2024/06/02 00:28
今天我来总结一下vue中computed 和 watch的异同!
一、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>
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 } }})
js: 利用computed 来写
new Vue({ el:"#myDiv", data:{ firstName:"Den", lastName:"wang", }, computed:{ fullName:function(){ return this.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"); return this.firstName + " " +this.lastName; }, } }
三 、watch 方法
虽然计算属性在大多数情况下是非常适合的,但是在有些情况下我们需要自定义一个watcher,在数据变化时来执行异步操作,这时watch是非常有用的。
阅读全文
1 1
- vue2 中 computed 和 watch 的异同?
- vue中computed 和 watch的异同
- vue开发:vue中computed 和 watch的异同
- vue中computed和watch区别
- computed和watch的使用场景
- vue中watch和computed属性作用及区别
- methods和computed和watch的联系和区别
- Vuejs中关于computed、methods、watch的区别
- Vuejs中关于computed、methods、watch的区别
- Vue.js的computed和watch用法及区别
- computed属性和watch属性的区别之二【computed的基本用法】
- computed属性和watch属性的区别之四【购物车之computed】
- computed与methods的异同
- computed属性和watch属性的区别之一【watch的基本用法】
- computed属性和watch属性的区别之三【购物车之watch】
- Vue filter computed watch 的用法
- vue.js中的computed和methods和watch之间的区别
- 从作用机制和性质上看待methods,watch和computed的关系
- Codeforces 500A New Year Transportation 题解
- 解决微信页面中ios音乐不能自动播放问题
- php日周月排行版
- 策略模式
- Fibonacci从m-n输出
- vue2 中 computed 和 watch 的异同?
- Java设计person类,有姓名,年龄,性别。要求:该类至多只能创建一男,一女两个对象。
- 让tomcat支持软连接,实现快速回滚【转】
- 通过Scanner从控制台获取数据
- TCP连接的状态转移
- jquery一些对元素的操作
- UIScrollView实现图片轮播器及其无限循环效果
- jQuery.scrollTop() 函数详解
- 生产者和消费者的简单例子