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. CloseableHttpClient获取https请求不验证证书

    创建---调用 CloseableHttpClient httpclient = getHttpsClient(); /** * 获取https连接(不验证证书) * * @return */ pri ...

  2. LOJ.6066.[2017山东一轮集训Day3]第二题(树哈希 二分)

    LOJ 被一件不愉快的小事浪费了一个小时= =. 表示自己(OI方面的)智商没救了=-= 比较显然 二分+树哈希.考虑对树的括号序列进行哈希. 那么每个点的\(k\)子树的括号序列,就是一段区间去掉距 ...

  3. 04flask_scripts使用

    1,flask_script作用 flask_script的作用是可以通过命令行的实行来操作Flask,例如通过命令跑一个开发版本的服务器,设置数据库,定时任务等, 我们把脚本命令代码放在一个叫做ma ...

  4. Vue(三十)公共组件

    以 分页 组件为例:(根据自己具体业务编写) 1.pagination.vue <template> <!-- 分页 --> <div class="table ...

  5. centos7搭建本地 Remix

    由于最近要弄加入某联盟链,是基于ETH 所以要弄一个开发环境 一.准备 安装 nodejs,npm,git 二.安装 git clone https://github.com/ethereum/rem ...

  6. SpringBoot报错:Table 'database_name.hibernate_sequence' doesn't exist

    引起条件: SpringBoot+JPA插入包含自增字段的对象 @Id @GeneratedValue private Integer id; 解决方法: 给注解添加属性 @Id @Generated ...

  7. web 11

    Obtaining the JSON: 1.首先,我们将把要检索的JSON的URL存储在变量中. 2.要创建请求,我们需要使用new关键字从XMLHttpRequest构造函数创建一个新的请求对象实例 ...

  8. React组件和生命周期简介

        React 简介----React 是 Facebook 出品的一套颠覆式的前端开发类库.为什么说它是颠覆式的呢? 内存维护虚拟 DOM 对于传统的 DOM 维护,我们的步骤可能是:1.初始化 ...

  9. vue三级联动

    <select @change="getArea(province_id,1)" v-model="province_id"> <option ...

  10. java简单的双色球摇号程序

    import java.util.HashSet; import java.util.Random; import java.util.Set; /** * LotteryClient * @auth ...