详解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 相关文章推荐
javascript globalStorage类代码
Jun 04 Javascript
Angular的MVC和作用域
Dec 26 Javascript
JS实现两周内自动登录功能
Mar 23 Javascript
Angularjs 实现移动端在线测评效果(推荐)
Apr 05 Javascript
vue中引用阿里字体图标的方法
Feb 10 Javascript
一个基于react的图片裁剪组件示例
Apr 18 Javascript
JS/HTML5游戏常用算法之路径搜索算法 随机迷宫算法详解【普里姆算法】
Dec 13 Javascript
前端路由&amp;webpack基础配置详解
Jun 10 Javascript
使用 webpack 插件自动生成 vue 路由文件的方法
Aug 20 Javascript
vue+element-ui+axios实现图片上传
Aug 20 Javascript
JavaScript如何处理移动端拍摄图片旋转问题
Nov 16 Javascript
js抽奖转盘实现方法分析
May 16 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
mysql+php分页类(已测)
2008/03/31 PHP
php实现分页显示
2015/11/03 PHP
PHP微信红包API接口
2015/12/05 PHP
PHP共享内存用法实例分析
2016/02/12 PHP
[原创]静态页面也可以实现预览 列表不同的显示方式
2006/10/14 Javascript
向大师们学习Javascript(视频与PPT)
2009/12/27 Javascript
NodeJS框架Express的模板视图机制分析
2011/07/19 NodeJs
ajax页面无刷新 IE下遭遇Ajax缓存导致数据不更新的问题
2012/12/11 Javascript
JS实现图片预加载无需等待
2012/12/21 Javascript
js实现快速分享功能(你的文章分享工具)
2013/06/25 Javascript
禁止iframe脚本弹出的窗口覆盖了父窗口的方法
2014/09/06 Javascript
ReactJs设置css样式的方法
2017/06/08 Javascript
vue.js评论发布信息可插入QQ表情功能
2017/08/08 Javascript
vue-router实现组件间的跳转(参数传递)
2017/11/07 Javascript
vue项目中用cdn优化的方法
2018/01/03 Javascript
vue 之 css module的使用方法
2018/12/04 Javascript
Python计算回文数的方法
2015/03/11 Python
Python最基本的数据类型以及对元组的介绍
2015/04/14 Python
Python实现的排列组合计算操作示例
2017/10/13 Python
浅谈pandas用groupby后对层级索引levels的处理方法
2018/11/06 Python
对Python3中列表乘以某一个数的示例详解
2019/07/20 Python
解决windows上安装tensorflow时报错,“DLL load failed: 找不到指定的模块”的问题
2020/05/20 Python
Python中Yield的基本用法
2020/10/18 Python
Python读写锁实现实现代码解析
2020/11/28 Python
CSS3 Flexbox中flex-shrink属性的用法示例介绍
2013/12/30 HTML / CSS
使用layui实现左侧菜单栏及动态操作tab项的方法
2020/11/10 HTML / CSS
国外最大的眼镜网站:Coastal
2017/08/09 全球购物
Zooplus罗马尼亚:宠物食品和配件
2019/11/02 全球购物
优秀的计算机专业求职信范文
2013/12/27 职场文书
公司同意接收函
2014/01/13 职场文书
旅游专业毕业生自荐书
2014/06/30 职场文书
2015届本科毕业生自我鉴定
2014/09/27 职场文书
学校党委副书记个人对照检查材料思想汇报
2014/09/28 职场文书
工厂采购员岗位职责
2015/04/07 职场文书
2015年信贷员工作总结
2015/04/28 职场文书
电工实训心得体会
2016/01/14 职场文书