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实现指令式动态追加小球动画组件的步骤
Dec 18 Vue.js
vue实现登录功能
Dec 31 Vue.js
基于Vue2实现移动端图片上传、压缩、拖拽排序、拖拽删除功能
Jan 05 Vue.js
解决vue使用vant轮播组件swipe + flex时文字抖动问题
Jan 07 Vue.js
vue实现一个获取按键展示快捷键效果的Input组件
Jan 13 Vue.js
聊聊vue 中的v-on参数问题
Jan 29 Vue.js
WebStorm无法正确识别Vue3组合式API的解决方案
Feb 18 Vue.js
vue打开新窗口并实现传参的图文实例
Mar 04 Vue.js
vue 中 get / delete 传递数组参数方法
Mar 23 Vue.js
vue+iview实现手机号分段输入框
Mar 25 Vue.js
vue封装数字翻牌器
Apr 20 Vue.js
vue修饰符.capture和.self的区别
Apr 22 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
图形数字验证代码
2006/10/09 PHP
使用Linux五年积累的一些经验技巧
2013/06/20 PHP
php输出1000以内质数(素数)示例
2014/02/16 PHP
PHP+jquery实时显示网站在线人数的方法
2015/01/04 PHP
PHP类型约束用法示例
2016/09/28 PHP
Laravel框架实现redis集群的方法分析
2017/09/14 PHP
laravel中数据显示方法(默认值和下拉option默认选中)
2019/10/11 PHP
一个tab标签切换效果代码
2009/03/27 Javascript
innerText和innerHTML 一些问题分析
2009/05/18 Javascript
JS获取页面input控件中所有text控件并追加样式属性
2013/02/25 Javascript
浅谈JavaScript中的作用域和闭包问题
2015/07/07 Javascript
JS实现的左侧竖向滑动菜单效果代码
2015/10/19 Javascript
仅一个form表单 js实现注册信息依次填写提交功能
2016/06/12 Javascript
Bootstrap Table使用方法详解
2016/08/01 Javascript
jQuery fadeOut 异步实例代码详解
2016/08/18 Javascript
js中Number数字数值运算后值不对的解决方法
2017/02/28 Javascript
angularjs之$timeout指令详解
2017/06/13 Javascript
JS+canvas绘制的动态机械表动画效果
2017/09/12 Javascript
JS实现的贪吃蛇游戏完整实例
2019/01/18 Javascript
解决vuex数据页面刷新后初始化操作
2020/07/26 Javascript
Python标准库之循环器(itertools)介绍
2014/11/25 Python
python timestamp和datetime之间转换详解
2017/12/11 Python
使用python批量读取word文档并整理关键信息到excel表格的实例
2018/11/07 Python
对pandas写入读取h5文件的方法详解
2018/12/28 Python
python flask框架实现传数据到js的方法分析
2019/06/11 Python
Python基于time模块表示时间常用方法
2020/06/18 Python
Python编写万花尺图案实例
2021/01/03 Python
html5.2 dialog简介详解
2018/02/27 HTML / CSS
玩具反斗城西班牙网上商城:ToysRUs西班牙
2017/01/19 全球购物
益模软件Java笔试题
2012/03/27 面试题
Linux如何压缩可执行文件
2014/03/27 面试题
法律系毕业生求职信
2014/05/28 职场文书
高中生国庆节演讲稿范文2014
2014/09/21 职场文书
武侯祠导游词
2015/02/04 职场文书
公司财务管理制度
2015/08/04 职场文书
Python打包exe时各种异常处理方案总结
2021/05/18 Python