1.computed

  • computed是一种计算属性,用来监听属性的变化;
  • computed里面的方法调用的时候不需要加(),并且里面的方法必须要有一个返回值;
  • computed里面的方法不是通过事件来去触发的,而是当data中的属性发生了改变的时候会被触发;
  • computed最大的特点是当属性没有发生改变的时候,当前方法的值会从缓存中读取。
 <div id="app">
  <input type="text" v-model.number="a">
  <input type="text" v-model.number="b">
  <button @click="handleAdd()">计算</button>
  <p>结果为:{{sum}}</p> <!-- 执行methods中的handleAdd()方法后返回的结果 -->
  <p>computed结果:{{count}}</p> <!-- 执行computed中的count()方法后返回的结果 -->
</div>
 new Vue({
el:"#app",
data:{
a:"",
b:"",
sum:""
},
methods:{
handleAdd(){
this.sum = this.a+this.b; //只有点击事件触发时才会改变
}
},
computed:{
count(){
return this.a+this.b; //实时监听,只要data中数据发生改变返回的结果就会改变
}
}
})

2. watch

  • watch用来监听每一个属性的变化;
  • watch这个对象里面都是函数,函数的名称是data中的属性名称,watch中的函数是不需要调用的;
  • 当属性发生改变时就会触发watch中的函数,每一个函数都会接受到2个值,一个值是新值,一个是旧值。可以在watch当中进行新旧值的判断来减少虚拟DOM的渲染;
  • 只要属性发生改变就会触发它所对应的函数;
  • 如果我们需要对对象进行监听的时候,需要将属性设置为key值,val值为一个对象。对象中有2个参数,一个是handler函数,另一个是deep为true,这样才能实现深度监听。
 <div id="app">
<input type="text" v-model.number="a">
<input type="text" v-model.number="b">
<p>结果:{{sum}}</p>
<hr>
<input type="text" v-model="obj.name">
<input type="text" v-model="obj.age">
</div>
 new Vue({
el:"#app",
data:{
a:"",
b:"",
sum:"",
obj:{
name:"pinpinkc",
age:18
}
},
watch:{
a(newVal,oldVal){
if(newVal != oldVal){
this.sum = newVal+this.b;
}
console.log("a发生了改变",newVal,oldVal)
},
b(newVal,oldVal){
this.sum = newVal+this.a;
console.log("b发生了改变",newVal,oldVal)
},
obj:{
handler(newVal){
console.log("obj发生了改变",newVal)
},
deep:true
}
}
})

3. computed与watch的区别

  • computed在调用的时候不需要加() , watch不需要调用;
  • computed如果属性没有发生改变的时候会存缓存中读取值 , watch当属性发生改变的时候会接受到2个值,一个为新值,一个为旧值;
  • computed里面的函数必须要有一个return返回结果;
  • watch如果需要监听对象的情况下必须设置深度监听;
  • computed里面函数的名称可以随意命名,但是watch中函数的名称必须是data中属性的名称。

【Vue】----- computed与watch的区别的更多相关文章

  1. Vue.js中 computed 和 methods 的区别

    官方文档中已经有对其的解释了,在这里把我的理解记录一下Vue中的methods.watch.computed computed 的使用场景 HTML模板中的复杂逻辑表达式,为了防止逻辑过重导致不易维护 ...

  2. vue计算属性computed和methods的区别

    computed和methods的区别 在new Vue的配置参数中的computed和methods都可以处理大量的逻辑代码,但是什么时候用哪个属性,要好好区分一下才能做到正确的运用vue. com ...

  3. vue系列---理解Vue中的computed,watch,methods的区别及源码实现(六)

    _ 阅读目录 一. 理解Vue中的computed用法 二:computed 和 methods的区别? 三:Vue中的watch的用法 四:computed的基本原理及源码实现 回到顶部 一. 理解 ...

  4. vue中computed/method/watch的区别

    摘要:本文通过官方文档结合源码来分析computed/method/watch的区别. Tips:本文分析的源码版本是v2.6.11,文章中牵涉到vue响应式系统原理部分,如果不是很了解,建议先阅读上 ...

  5. vue computed 原理

    vue computed 主要依靠数据依赖来更新,这里不展示computed源代码,只展示核心思想. computed: { a(){ return this.b ++ } } data:{ b: 1 ...

  6. vue和react之间的区别

    1.Vue和React之间的区别 相同点: Vue和其他框架一样,都有组件开发和虚拟dom 都支持props进行父子组件之间的数据通信 都支持数据驱动视图,不直接操作真实dom 都支持服务器端的 渲染 ...

  7. Vue computed props pass params

    Vue computed props pass params vue 计算属性传参数 // 计算 spreaderAlias spreaderAlias () { console.log('this. ...

  8. vuex bug & vue computed setter

    vuex bug & vue computed setter https://vuejs.org/v2/guide/computed.html#Computed-Setter [Vue war ...

  9. Vue中computed与method的区别

    转载于:https://segmentfault.com/a/1190000014478664?utm_source=tag-newest 1.computed区别于method的两个核心 在官方文档 ...

随机推荐

  1. vue自定义键盘事件

    //自定义全局按键修饰符 Vue.config.keyCodes.f2 = 13;//enter为13此时F2==ENTER 调用;@keyup.f2='addData()'

  2. 如何使用yql实现跨域访问

    应用场景 调用百度的某个API, 例如:https://openapi.baidu.com/api 返回结果是:{"id":123,"name":"t ...

  3. 数据分析——numpy

    DIKW DATA-->INFOMATION-->KNOWLEDGE-->WISDOM 数据-->信息-->知识-->智慧 爬虫-->数据库-->数据分 ...

  4. python学习笔记(3)

    .................................................................................................... ...

  5. ntp---时钟同步服务

    NTP--时钟同步服务 地球分为东西十二个区域,共计 24 个时区 格林威治作为全球标准时间即 (GMT 时间 ),东时区以格林威治时区进行加,而西时区则为减. 地球的轨道并非正圆,在加上自转速度逐年 ...

  6. Ubuntu wpa 代替network-manager

    1. Ubuntu启动时,如果出现60秒等待:Waiting up to 60 seconds for network configuration 解决方法: a. /etc/init ,打开fail ...

  7. RDSS和RNSS

    RNSS英文全称Radio Navigation Satellite System,由用户接收卫星无线电导航信号,是一种卫星无线电导航业务,自主完成至少到4颗卫星的距离测量,进行用户位置,速度及航行参 ...

  8. Linux shell编程-退出的状态码

    linux 提供了一个专门的变量$?来保存上个已执行命令的状态码 linux 的错误状态退出状态码没有什么标准可遵循,但有一些参考 状态码 描述 0 命令成功结束 1 一般性未知错误 2 不适合的sh ...

  9. d3.js,初遇

    接触d3完全是由兴趣所致,废话不多说看代码: var dataArray = [23, 13, 21, 14, 37, 15, 18, 34, 30];这是这个图所需要的数据,其实这个柱状图最初不长这 ...

  10. angular学习笔记(三)

    1.安装npm install --save @angular/material@2.0.0-beta.72.安装http://chrome-extension-downloader.com安装aug ...