Vue中computed和watch有哪些区别


Posted in Vue.js onDecember 19, 2020

计算属性computed:

  • 支持缓存,只有依赖数据发生改变,才会重新进行计算
  • 不支持异步,当computed内有异步操作时无效,无法监听数据的变化
  • computed 属性值会默认走缓存,计算属性是基于它们的响应式依赖进行缓存的,也就是基于data中声明过或者父组件传递的props中的数据通过计算得到的值
  • 如果一个属性是由其他属性计算而来的,这个属性依赖其他属性,是一个多对一或者一对一,一般用computed
  • 如果computed属性属性值是函数,那么默认会走get方法;函数的返回值就是属性的属性值;在computed中的,属性都有一个get和一个set方法,当数据变化时,调用set方法。
var vm = new Vue({
 el: '#app',
 data: {
  message: 'hello'
 },
 template: `
 <div> <p>我是原始值: "{{ message }}"</p> <p>我是计算属性的值: "{{ computedMessage}}"</p> // computed 在 DOM 里直接使用不需要调用 </div> `,
 computed: {
  // 计算属性的 getter   computedMessage: function () {
   // `this` 指向 vm 实例    return this.message.split('').reverse().join('')
  }
 }
})

结果:

我是原始值: "Hello"
我是计算属性的值: "olleH"

如果不使用计算属性,那么 message.split('').reverse().join('') 就会直接写到 template 里,那么在模版中放入太多声明式的逻辑会让模板本身过重,尤其当在页面中使用大量复杂的逻辑表达式处理数据时,会对页面的可维护性造成很大的影响

而且计算属性如果依赖不变的话,它就会变成缓存,computed 的值就不会重新计算

所以,如果数据要通过复杂逻辑来得出结果,那么就推荐使用计算属性

侦听属性watch

  • 不支持缓存,数据变,直接会触发相应的操作。
  • watch支持异步;监听的函数接收两个参数,第一个参数是最新的值;第二个参数是输入之前的值;
  • 当一个属性发生变化时,需要执行对应的操作;一对多;
  • 监听数据必须是data中声明过或者父组件传递过来的props中的数据,当数据变化时,触发其他操作,函数有两个参数:
new Vue({
 data: {
  n: 0,
  obj: {
   a: "a"
  }
 },
 template: `
 <div> <button @click="n += 1">n+1</button> <button @click="obj.a += 'hi'">obj.a + 'hi'</button> <button @click="obj = {a:'a'}">obj = 新对象</button> </div> `,
 watch: {
  n() {
   console.log("n 变了");
  },
  obj:{
   handler: function (val, oldVal) { 
   console.log("obj 变了")
  },
   deep: true // 该属性设定在任何被侦听的对象的 property 改变时都要执行 handler 的回调,不论其被嵌套多深   },
  "obj.a":{
   handler: function (val, oldVal) { 
   console.log("obj.a 变了")
  },
   immediate: true // 该属性设定该回调将会在侦听开始之后被立即调用   }
 }
}).$mount("#app");

不应该使用箭头函数来定义 watcher 函数,因为箭头函数没有 this,它的 this 会继承它的父级函数,但是它的父级函数是 window,导致箭头函数的 this 指向 window,而不是 Vue 实例

  • deep 控制是否要看这个对象里面的属性变化
  • immediate 控制是否在第一次渲染是执行这个函数

vm.$watch() 的用法和 watch 回调类似

  • vm.$watch('data属性名', fn, {deep: .., immediate: ..})
vm.$watch("n", function(val, newVal){
   console.log("n 变了");
},{deep: true, immediate: true})

总结

  • 如果一个数据需要经过复杂计算就用 computed
  • 如果一个数据需要被监听并且对数据做一些操作就用 watch

以上就是Vue中computed和watch有哪些区别的详细内容,更多关于Vue中computed和watch的区别的资料请关注三水点靠木其它相关文章!

Vue.js 相关文章推荐
实用的 vue tags 创建缓存导航的过程实现
Dec 03 Vue.js
Vue使用鼠标在Canvas上绘制矩形
Dec 24 Vue.js
详解Vue2的diff算法
Jan 06 Vue.js
如何在vue中使用HTML 5 拖放API
Jan 14 Vue.js
Vue实现多页签组件
Jan 14 Vue.js
Vue 事件的$event参数=事件的值案例
Jan 29 Vue.js
vue-router懒加载的3种方式汇总
Feb 28 Vue.js
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
Mar 01 Vue.js
详解Vue中$props、$attrs和$listeners的使用方法
Feb 18 Vue.js
深入讲解Vue中父子组件通信与事件触发
Mar 22 Vue.js
vue实现拖拽交换位置
Apr 07 Vue.js
vue判断按钮是否可以点击
Apr 09 Vue.js
Vue与React的区别和优势对比
Dec 18 #Vue.js
Vue实现指令式动态追加小球动画组件的步骤
Dec 18 #Vue.js
vue+elementUI动态增加表单项并添加验证的代码详解
Dec 17 #Vue.js
vue 数据操作相关总结
Dec 17 #Vue.js
Vue 组件注册全解析
Dec 17 #Vue.js
vue图片裁剪插件vue-cropper使用方法详解
Dec 16 #Vue.js
vue实现图片裁剪后上传
Dec 16 #Vue.js
You might like
实现dedecms全站URL静态化改造的代码
2007/03/29 PHP
PHP操作文件类的函数代码(文件和文件夹创建,复制,移动和删除)
2011/11/10 PHP
THINKPHP支持YAML配置文件的设置方法
2015/03/17 PHP
PHP实现批量修改文件后缀名的方法
2015/07/30 PHP
jQuery:节点(插入,复制,替换,删除)操作
2013/03/04 Javascript
jquery 页面滚动到指定DIV实现代码
2013/09/25 Javascript
一个html5播放视频的video控件只支持android的默认格式mp4和3gp
2014/05/08 Javascript
jQuery中[attribute^=value]选择器用法实例
2014/12/31 Javascript
javascript实现全角与半角字符的转换
2015/01/07 Javascript
学习JavaScript设计模式之享元模式
2016/01/18 Javascript
AngularJS 面试题集锦
2016/09/06 Javascript
jQuery实现邮箱下拉列表自动补全功能
2016/09/08 Javascript
js实现右键自定义菜单
2016/12/03 Javascript
vue实现ajax滚动下拉加载,同时具有loading效果(推荐)
2017/01/11 Javascript
JavaScript中的遍历详解(多种遍历)
2017/04/07 Javascript
Node.js利用断言模块assert进行单元测试的方法
2017/09/28 Javascript
解决Vue.js 2.0 有时双向绑定img src属性失败的问题
2018/03/14 Javascript
微信小程序监听用户登录事件的实现方法
2019/11/11 Javascript
微信小程序之左右布局的实现代码
2019/12/13 Javascript
JavaScript设计模式之策略模式实现原理详解
2020/05/29 Javascript
vue 实现基础组件的自动化全局注册
2020/12/25 Vue.js
使用70行Python代码实现一个递归下降解析器的教程
2015/04/17 Python
python最长回文串算法
2018/06/04 Python
无法使用pip命令安装python第三方库的原因及解决方法
2018/06/12 Python
pyQT5 实现窗体之间传值的示例
2019/06/20 Python
简单了解Python生成器是什么
2019/07/02 Python
详解CSS3中border-image的使用
2015/07/18 HTML / CSS
Ryderwear美国官网:澳大利亚高端健身训练装备品牌
2018/04/24 全球购物
应届大学生求职信
2013/12/01 职场文书
幼儿园课题实施方案
2014/05/14 职场文书
2014年社区教育工作总结
2014/12/02 职场文书
财务会计岗位职责
2015/02/03 职场文书
2016新年问候语大全
2015/11/11 职场文书
CSS3常见动画的实现方式
2021/04/14 HTML / CSS
Vue实现跑马灯样式文字横向滚动
2021/11/23 Vue.js
Smart 2 车辆代号 HC11 全新谍照曝光
2022/04/21 数码科技