详解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 相关文章推荐
jquery 如何动态添加、删除class样式方法介绍
Nov 07 Javascript
js渐变显示渐变消失示例代码
Aug 01 Javascript
Extjs Label的 fieldLabel和html属性值对齐的方法
Jun 15 Javascript
javascript下拉框选项单击事件的例子分享
Mar 04 Javascript
ANGULARJS中使用JQUERY分页控件
Sep 16 Javascript
JavaScript+html5 canvas制作的圆中圆效果实例
Jan 27 Javascript
jquery实现列表上下移动功能
Feb 25 Javascript
Bootstrap多级导航栏(级联导航)的实现代码
Mar 08 Javascript
微信小程序支付之c#后台实现方法
Oct 19 Javascript
微信小程序--特定区域滚动到顶部时固定的方法
Apr 28 Javascript
使用Element的InfiniteScroll 无限滚动组件报错的解决
Jul 27 Javascript
vue点击Dashboard不同内容 跳转到同一表格的实例
Nov 13 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
德生BCL3000的电路分析和打磨
2021/03/02 无线电
php防注
2007/01/15 PHP
PHP跳转页面的几种实现方法详解
2013/06/08 PHP
php for 循环使用的简单实例
2016/06/02 PHP
PHP单态模式简单用法示例
2016/11/16 PHP
PHP对象、模式与实践之高级特性分析
2016/12/08 PHP
PHP SFTP实现上传下载功能
2017/07/26 PHP
PHP实现APP微信支付的实例讲解
2018/02/10 PHP
PHP设计模式之模板方法模式定义与用法详解
2018/04/02 PHP
laravel model模型处理之修改查询或修改字段时的类型格式案例
2019/10/17 PHP
打开超链需要“确认”对话框的方法
2007/03/08 Javascript
jquery教程ajax请求json数据示例
2014/01/13 Javascript
JavaScript中的依赖注入详解
2015/03/18 Javascript
JS原型链 详解及示例代码
2016/09/06 Javascript
js禁止Backspace键使浏览器后退的实现方法
2017/09/01 Javascript
基于vue实现网站前台的权限管理(前后端分离实践)
2018/01/13 Javascript
js统计页面上每个标签的数量实例代码
2018/05/29 Javascript
原生js实现的金山打字小游戏(实例代码详解)
2020/03/16 Javascript
详解JavaScript 异步编程
2020/07/13 Javascript
JS typeof fn === 'function' &amp;&amp; fn()详解
2020/08/22 Javascript
[15:56]Heroes18_暗影萨满(完美)
2014/10/31 DOTA
[04:49]期待西雅图之战 2016国际邀请赛中国区预选赛WINGS战队赛后采访
2016/06/29 DOTA
Python处理PDF及生成多层PDF实例代码
2017/04/24 Python
《与孩子一起学编程》python自测题
2018/05/27 Python
浅谈Tensorflow由于版本问题出现的几种错误及解决方法
2018/06/13 Python
Python检查和同步本地时间(北京时间)的实现方法
2018/12/03 Python
学习python分支结构
2019/05/17 Python
python基于K-means聚类算法的图像分割
2019/10/30 Python
PyCharm中Matplotlib绘图不能显示UI效果的问题解决
2020/03/12 Python
Pycharm生成可执行文件.exe的实现方法
2020/06/02 Python
Boden英国官网:英国知名原创时装品牌
2018/11/06 全球购物
如何将字串String转换成整数int
2015/02/21 面试题
业务主管岗位职责范本
2013/12/25 职场文书
村级换届选举方案
2014/05/10 职场文书
领导班子四风问题个人对照检查材料
2014/10/04 职场文书
Django框架之路由用法
2022/06/10 Python