详解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 相关文章推荐
JS getMonth()日期函数的值域是0-11
Feb 15 Javascript
Javascript实现视频轮播在pc端与移动端均可
Sep 29 Javascript
javascript对中文按照拼音排序代码
Aug 20 Javascript
深入理解JavaScript系列(25):设计模式之单例模式详解
Mar 03 Javascript
Vue中添加过渡效果的方法
Mar 16 Javascript
深究AngularJS如何获取input的焦点(自定义指令)
Jun 12 Javascript
js中int和string数据类型互相转化实例
Jan 16 Javascript
解决vue-cli webpack打包开启Gzip 报错问题
Jul 24 Javascript
vue eslint简要配置教程详解
Jul 26 Javascript
seajs和requirejs模块化简单案例分析
Aug 26 Javascript
原生js实现日历效果
Mar 02 Javascript
vue单元格多列合并的实现
Nov 26 Vue.js
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中文分词的简单实现代码分享
2011/07/17 PHP
php定义一个参数带有默认值的函数实例分析
2015/03/16 PHP
详解laravel安装使用Passport(Api认证)
2018/07/27 PHP
php的扩展写法总结
2019/05/14 PHP
laravel Task Scheduling(任务调度)在windows下的使用详解
2019/10/22 PHP
jquery 框架使用教程 AJAX篇
2009/10/11 Javascript
javascript for循环设法提高性能
2010/02/24 Javascript
通过下拉框的值来确定输入框是否可以为空的代码
2011/10/18 Javascript
40款非常棒的jQuery 插件和制作教程(系列一)
2011/10/26 Javascript
js修改table中Td的值(定义td的单击事件)
2013/01/10 Javascript
angularjs中的单元测试实例
2014/12/06 Javascript
jquery解决客户端跨域访问问题
2015/01/06 Javascript
js实现点击链接后窗口缩小并居中的方法
2015/03/02 Javascript
kindeditor修复会替换script内容的问题
2015/04/03 Javascript
JavaScript入门教程之引用类型
2016/05/04 Javascript
JavaScript中解决多浏览器兼容性23个问题的快速解决方法
2016/05/19 Javascript
javascript实现无法关闭的弹框
2016/11/27 Javascript
如何使用JS在HTML中自定义字符串格式化
2017/07/20 Javascript
微信小程序左滑动显示菜单功能的实现
2018/06/14 Javascript
Vue + element 实现多选框组并保存已选id集合的示例代码
2020/06/03 Javascript
[02:42]2014DOTA2国际邀请赛 三冰专访:我会打到Ti20
2014/07/13 DOTA
[03:27]《辉夜杯》线下训练营 导师CU和海涛指点迷津
2015/10/23 DOTA
python如何在终端里面显示一张图片
2016/08/17 Python
Python正则替换字符串函数re.sub用法示例
2017/01/19 Python
利用pandas将numpy数组导出生成excel的实例
2018/06/14 Python
Python 通过requests实现腾讯新闻抓取爬虫的方法
2019/02/22 Python
Python Django form 组件动态从数据库取choices数据实例
2020/05/19 Python
Python如何生成xml文件
2020/06/04 Python
如何快速理解python的垃圾回收机制
2020/09/01 Python
初中生自我鉴定
2014/02/04 职场文书
投资合作协议书范本
2014/04/17 职场文书
财务部副经理岗位职责范本
2014/06/17 职场文书
学校运动会广播稿
2014/10/11 职场文书
道德模范事迹材料
2014/12/20 职场文书
pandas 操作 Excel操作总结
2021/03/31 Python
Redis高并发缓存架构性能优化
2022/05/15 Redis