详解vue中computed 和 watch的异同


Posted in Javascript onJune 30, 2017

一、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)

  1. setter 方法在设置值是触发。
  2. getter 方法在获取值时触发。
computed:{
  fullName:{
  //这里用了es6书写方法
    set(){
       alert("set");
    },
    get(){
      alert("get");
      return this.firstName + " " +this.lastName;
    },

  }
 }

三 、watch 方法

虽然计算属性在大多数情况下是非常适合的,但是在有些情况下我们需要自定义一个watcher,在数据变化时来执行异步操作,这时watch是非常有用的。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
同一个表单 根据要求递交到不同页面的实现方法小结
Aug 05 Javascript
JavaScript类和继承 constructor属性
Mar 04 Javascript
Javascript(AJAX)解析XML的代码(兼容FIREFOX/IE)
Jul 11 Javascript
删除select中所有option选项jquery代码
Aug 12 Javascript
JavaScript实现函数返回多个值的方法
Jun 09 Javascript
javascript与Python快速排序实例对比
Aug 10 Javascript
jquery实现input框获取焦点的简单实例
Jan 26 Javascript
jQuery导航条固定定位效果实例代码
May 26 jQuery
vue绑定事件后获取绑定事件中的this方法
Sep 15 Javascript
jquery-ui 进度条功能示例【测试可用】
Jul 25 jQuery
微信小程序中的video视频实现 自定义播放按钮、封面图、视频封面上文案
Jan 02 Javascript
如何在面试中手写出javascript节流和防抖函数
Oct 22 Javascript
JS 组件系列之Bootstrap Table 冻结列功能IE浏览器兼容性问题解决方案
Jun 30 #Javascript
vue2.0 axios前后端数据处理实例代码
Jun 30 #Javascript
JS 组件系列之Bootstrap Table的冻结列功能彻底解决高度问题
Jun 30 #Javascript
MUI实现上拉加载和下拉刷新效果
Jun 30 #Javascript
js实现京东轮播图效果
Jun 30 #Javascript
jquery实现一个全局计时器(商城可用)
Jun 30 #jQuery
Vue和Bootstrap的整合思路详解
Jun 30 #Javascript
You might like
说说PHP的autoLoad自动加载机制
2012/09/27 PHP
php foreach如何跳出两层循环(详解)
2016/11/05 PHP
使用laravel的migrate创建数据表的方法
2019/09/30 PHP
如何在Laravel5.8中正确地应用Repository设计模式
2019/11/26 PHP
Javascript 设计模式(二) 闭包
2010/05/26 Javascript
Javascript模块化编程(一)模块的写法最佳实践
2013/01/17 Javascript
jquery通过closest选择器修改上级元素的方法
2015/03/17 Javascript
js中 javascript:void(0) 用法详解
2015/08/11 Javascript
利用Javascript仿Excel的数据透视分析功能
2016/09/07 Javascript
JS框架之vue.js(深入三:组件1)
2016/09/29 Javascript
使用jquery+iframe做一个ajax上传效果(实例)
2017/08/24 jQuery
nodejs创建简易web服务器与文件读写的实例
2017/09/07 NodeJs
mock.js模拟数据实现前后端分离
2019/07/24 Javascript
Bootstrap FileInput实现图片上传功能
2021/01/28 Javascript
[02:04]2014DOTA2国际邀请赛 BBC小组赛第三天总结
2014/07/12 DOTA
[45:52]2018DOTA2亚洲邀请赛 4.1小组赛 A组加赛 LGD vs Liquid
2018/04/02 DOTA
python列表操作实例
2015/01/14 Python
Python函数参数类型*、**的区别
2015/04/11 Python
python计算文本文件行数的方法
2015/07/06 Python
同时安装Python2 &amp; Python3 cmd下版本自由选择的方法
2017/12/09 Python
Selenium定位元素操作示例
2018/08/10 Python
Python集中化管理平台Ansible介绍与YAML简介
2019/06/12 Python
利用Python实现手机短信监控通知的方法
2019/07/22 Python
python字典的值可以修改吗
2020/06/29 Python
css3 给背景设置渐变色的方法
2019/09/12 HTML / CSS
让IE9以下版本的浏览器兼容HTML5的方法
2014/03/12 HTML / CSS
海外淘书首选:AbeBooks
2017/07/31 全球购物
美国专业汽车音响和移动电子产品零售商:Car Toys
2019/05/13 全球购物
毕业生在校学习的自我评价分享
2013/10/08 职场文书
新闻编辑自荐信
2013/11/03 职场文书
法警的竞聘演讲稿
2014/01/02 职场文书
四风问题党员个人整改措施
2014/10/27 职场文书
写给妈妈的感谢信
2015/01/22 职场文书
三八妇女节慰问信
2015/02/14 职场文书
2015企业年终工作总结范文
2015/05/27 职场文书
Jpa Specification如何实现and和or同时使用查询
2021/11/23 Java/Android