详解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 相关文章推荐
利用onresize使得div可以随着屏幕大小而自适应的代码
Jan 15 Javascript
js中scrollHeight,scrollWidth,scrollLeft,scrolltop等差别介绍
May 16 Javascript
实例代码讲解jquery easyui动态tab页
Nov 17 Javascript
基于javascript简单实现对身份证校验
Jan 25 Javascript
详解angularJS动态生成的页面中ng-click无效解决办法
Jun 19 Javascript
vue组件发布到npm简单步骤
Nov 30 Javascript
Vue 页面跳转不用router-link的实现代码
Apr 12 Javascript
使用Three.js实现太阳系八大行星的自转公转示例代码
Apr 09 Javascript
仿ElementUI实现一个Form表单的实现代码
Apr 23 Javascript
layui的布局和表格的渲染以及动态生成表格的方法
Sep 18 Javascript
vue+vant-UI框架实现购物车的复选框全选和反选功能
Nov 05 Javascript
JavaScript如何判断对象有某属性
Jul 03 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
剧场版动画《PSYCHO-PASS 3 FIRST INSPECTOR》3月27日日本上映!
2020/03/06 日漫
咖啡知识 咖啡养豆要养多久 排气又是什么
2021/03/06 新手入门
透析PHP的配置文件php.ini
2006/10/09 PHP
php下MYSQL limit的优化
2008/01/10 PHP
在wamp集成环境下升级php版本(实现方法)
2013/07/01 PHP
Laravel 框架基于自带的用户系统实现登录注册及错误处理功能分析
2020/04/14 PHP
javascript jscroll模拟html元素滚动条
2012/12/18 Javascript
JavaScript实现俄罗斯方块游戏过程分析及源码分享
2015/03/23 Javascript
bootstrap网页框架的使用方法
2016/05/10 Javascript
jQuery实现简单弹窗遮罩效果
2017/02/27 Javascript
bootstrap插件treeview实现全选父节点下所有子节点和反选功能
2017/07/21 Javascript
Vue中遍历数组的新方法实例详解
2019/07/21 Javascript
Vue优化:常见会导致内存泄漏问题及优化详解
2020/08/04 Javascript
antd Select下拉菜单动态添加option里的内容操作
2020/11/02 Javascript
[01:14]辉夜杯战队访谈宣传片—NEWBEE.Y
2015/12/26 DOTA
[05:59]2018DOTA2国际邀请赛寻真——只为胜利的Secret
2018/08/13 DOTA
Python中使用HTMLParser解析html实例
2015/02/08 Python
Python import自定义模块方法
2015/02/12 Python
python算法演练_One Rule 算法(详解)
2017/05/17 Python
使用Turtle画正螺旋线的方法
2017/09/22 Python
Python实现socket非阻塞通讯功能示例
2019/11/06 Python
Pycharm 2020.1 版配置优化的详细教程
2020/08/07 Python
利用CSS3把图片变成灰色模式的实例代码
2016/09/06 HTML / CSS
基于CSS3的animation属性实现微信拍一拍动画效果
2020/06/22 HTML / CSS
canvas环形倒计时组件的示例代码
2018/06/14 HTML / CSS
GNC健安喜美国官网:美国第一营养品牌
2016/07/22 全球购物
Tessabit日本:集世界奢侈品和设计师品牌的意大利精品买手店
2020/01/07 全球购物
Chi Chi London官网:购买连衣裙和礼服
2020/10/25 全球购物
小学运动会广播稿200字(十二篇)
2014/01/14 职场文书
服务员岗位职责
2014/01/29 职场文书
弘扬职业精神演讲稿
2014/03/20 职场文书
先进个人申报材料
2014/12/30 职场文书
后勤个人工作总结
2015/02/28 职场文书
大学生心理健康活动总结
2015/05/08 职场文书
详解运行Python的神器Jupyter Notebook
2021/06/03 Python
浅析NIO系列之TCP
2021/06/15 Java/Android