vue入门:(计算属性和侦听器)
- methods
- watch
- computed
一、methods-方法
在数据渲染是需要基于多个数据时第一种方法,可以采用methods属性中的方法计算返回值来实现,先来看示例:
<div id="example">{{describe()}}</div>
<script>
var vm = new Vue({
el:"#example",
data:{
name:'他乡踏雪',
looks:'beautiful',
// describe:'他乡踏雪:beautiful' -- 注意data中的命名不能与methods中的命名一致,会发生冲突
// 渲染数据时会先取data中的值,即便在表达式中写入的是方法执行也会取data中的数据(采用正则匹配)相当于字符串做方法执行:报错
},
methods:{
describe(){
return this.name + this.looks;
}
}
});
</script>
methods并且可以实现当数据发生变化时,或者在相关表达式被被执行时(比如示例中),methods就会触发执行, 但是methods还有一种情况就暴露了他的缺点,来看下面的示例:
<div id="example">{{describe()}}{{age}}</div>
如果结构是这样的情况,methods中的describe在age发生变化时是不应该执行的,但是他却会执行,所以methods的执行不只是在数据变化和表达式执行时,而且还会在DOM内部分结构重新渲染时也会触发执行。这种情况就产生了额外的计算,影响性能。
二、watch-侦听器
基于对methods渲染触发问题的思考,vue还提供了一个侦听器来实现只有相关数据发生变化时才触发执行的watch,来看示例:
<div id="example">{{describe}}{{age}}</div>
<script>
var vm = new Vue({
el:"#example",
data:{
name:'他乡踏雪',
looks:'beautiful',
describe:"他乡踏雪 beautiful",
age:18
},
watch:{
name(){
this.bescribe = this.name + " " + this.looks
},
looks(){
this.bescribe = this.name + " " + this.looks
}
}
});
侦听器watch就是在watch属性中定义与data中数据同名的方法,当data中的某个数据发生变化时,watch中对应的侦听方法就会触发执行。所以使用watch的侦听机制就不会发生像methods那样非相关数据触发的渲染也会导致方法执行,所以从这个角度来看,watch比methods的性能要好些。
三、computed-计算属性
watch和methods都存在一个类似的问题,就是代码冗余,vue还提供了一个解决方案,就是计算属性computed,看看通过计算属性computed改良上面的示例代码:
<div id="example">{{describe}}{{age}}</div>
<script>
var vm = new Vue({
el:"#example",
data:{
name:'他乡踏雪',
looks:'beautiful',
age:18
},
computed:{
describe(){
return this.name + " " + this.looks;
}
}
});
</script>
使用计算属性可以直接将属性名用于结构表达式中渲染数据,免去了data中的重复定义数据,并且也只有在相关的数据发生变化时才会被触发,免去了watch中多个数据情况下重复监听。
计算属性computed的功能不只是用来实现计算数据渲染,还可以实现data数据的写入,其实上面的示例只是vue实例的getter方法,所以上面的示例代码可以改写成下面这样:
<div id="example">{{describe}}{{age}}</div>
<script>
var vm = new Vue({
el:"#example",
data:{
name:'他乡踏雪',
looks:'beautiful',
age:18
},
computed:{
describe:{
get(){
return this.name + " " + this.looks;
}
}
}
});
</script>
再来看看setter方法,所谓计算属性的setter方法就是当设置describe的值时,name和looks的值也会发生变化,具体来看示例代码:
<div id="example">{{describe}}{{age}}</div>
<script>
var vm = new Vue({
el:"#example",
data:{
name:'他乡踏雪',
looks:'beautiful',
age:18
},
computed:{
describe:{
get(){
return this.name + " " + this.looks;
},
set(newVal){
const names = newVal.split(' ');
this.name = names[0];
this.looks = names[1];
}
}
}
});
</script>
也就是说计算属性是可读可写的,还有就是computed有一个非常重要的特性就是当数据不发生变化时不会执行getter方法,这对于性能优化有很大的帮助,比如computed中的一个属性依赖多个数据渲染,但是在很多时候只会有部分数据发生变化,这时候是需要对发生变化的数据执行getter方法读取新的数据来实现渲染,其他的数据直接去缓存数据。
但是这也有一个闭端,就是有时候依赖的数据并非观察数据(非vue实例上的数据),但又要时时更新,比如下面这个示例:
get(){
return this.name + " " + this.looks + ' ' + Date.now();
}
当name和looks发生变化时,Date.now()始终渲染的是初始数据,不会更新,针对这种情况,vue在计算属性对象中指定了cache字段来控制是否开启缓存,cache的值为false时关闭缓存,会对每个依赖数据执行getter方法,cache默认为true表示读取缓存。所以上面的代码可以修正为:(这个关闭缓存好像失效了,待进一步测试确认)
//关闭缓存
cache:false,
get(){
return this.name + " " + this.looks + ' ' + Date.now();
}
到了这里你是不是感觉computed有点过分完美,其实不然,计算属性也是存在缺陷的,比如计算属性的节点被移除,并且模板中其他地方没有在引用该属性的时候,那么这个getter方法就不会执行,比如下面这个示例:(来源vue.js权威指南55页)
<div id="example">
<button @click = 'toggleShow'>Toggle Show Total Price</button>
<p v-if = "showTotal">Total Price = {{totalPrice}}</p>
</div>
<script>
var vm = new Vue({
el:"#example",
data:{
showTotal:true,
basePrice:100,
sum:0
},
computed:{
totalPrice(){
console.log(this.sum++);
return this.basePrice;
}
},
methods:{
toggleShow(){
this.basePrice = this.basePrice + 1;
this.showTotal = !this.showTotal;
}
}
});
</script>
在实例中,观察控制台的sum输出必须是在p标签显示的时候才会执行,并且sum的累加比basePrice累加要慢一倍。也就是证实了当计算属性computed的节点被移除后,并且模板中没有其他地方在引用的话,getter方法就不会执行。
要想他执行的话可以采用以下方法:
<div id="example">
<button @click = 'toggleShow'>Toggle Show Total Price</button>
<p>{{totalPrice}}</p>
<p v-if = "showTotal">Total Price = {{totalPrice}}</p>
</div>
只能是当计算属性一直出现在模板中,getter方法才会被执行。
——————————————————————
这里还有关于methods、watch、computed的适应场景分析待续。。。
vue入门:(计算属性和侦听器)的更多相关文章
- 一起学Vue之计算属性和侦听器
概述 在Vue开发中,模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.当你想要在模板中多次引用相同表达式时,就会更加难以处理.所以,对于任何复 ...
- vue基础——计算属性和侦听器
计算属性——介绍 模板内的表达式非常便利,但是设计他们的初衷是用于简单计算的.在模板中放入太多的逻辑会让模板太过沉重切难以维护.如下: <div id="example"&g ...
- Vue的计算属性和侦听器
1 计算属性:他是根据对象已有的属性计算出新的属性值.具有缓存的功能,如果原始属性不变,则用缓存.否则,重新计算. 前端 <form> <label>姓</label&g ...
- vue基础---计算属性和侦听器
[一]计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.例如: <div id="example"> ...
- vue之计算属性和侦听器
一.计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.例如: <div> {{ message.split('').rev ...
- vue 之 计算属性和侦听器
计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护.例如: <div> {{ message.split('').rever ...
- Vue.js之Vue计算属性、侦听器、样式绑定
前言 上一篇介绍了Vue的基本概念,这一篇介绍一下Vue的基本使用. 一.搭建一个Vue程序 1.1 搭建Vue环境 搭建Vue的开发环境总共有三种方法: 引入CDN <script src=& ...
- vue计算属性和侦听器
一.计算属性: main.js: var app = new Vue({ el: '#app', data: { math: 80, physics: 90, english: 30 }, compu ...
- Vue学习之vue中的计算属性和侦听器
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Vue.js 生命周期、计算属性及侦听器
一.创建一个Vue实例 每个Vue应用都是使用Vue函数创建一个Vue实例.所有的Vue组件都是一个Vue实例,并且接受相同的选项对象(一些根实例特有的选项除外). 数据和方法 当一个实例被创建后,它 ...
随机推荐
- Android系统服务 —— WMS与AMS
“可以毫不夸张的说,Android的framework层主要是由WMS.AMS还有View所构成,这三个模块穿插交互在整个framework中,掌握了它们之间的关系和每一个逻辑步骤,你对framewo ...
- SEO中常用的301永久重定向代码大全
301是永久重定向的意思,表示请求的网页已永久移动到新位置,服务器返回此响应(对 GET 或 HEAD 请求的响应)时,会自动将请求者转到新位置.其实301重定向在SEO中被广泛应用,也是被广泛认为比 ...
- Java线程池(Callable+Future模式)
转: Java线程池(Callable+Future模式) Java线程池(Callable+Future模式) Java通过Executors提供四种线程池 1)newCachedThreadPoo ...
- mysql 截取字符函数substring(param1,param2,param3) 的用法
substring(paramter1,paramter2,paramter3) 截取字段长度 paramter1 被截取的字段paramter2 从第几位开始截取,负数表示从末尾开始数,的位数开始 ...
- Jmeter使用实践-接口diff测试
Jmeter使用实践-接口diff测试 大多数人都使用 Jmeter 做过性能测试,但是在使用的过程中你会发现,它不仅可以做性能测试和功能测试,还能够满足基本的接口测试需求. 相比其他工具,Jmete ...
- iOS开发UIkit动力学UIDynamicAnimator一系列动画
UIDynamicAnimator类,通过这个类中的不同行为来实现一些动态特性. UIAttachmentBehavior(吸附),UICollisionBehavior(碰撞),UIGravityB ...
- Java集合(1):Collections工具类中的static方法
与Arrays一样,Collections类中也有一些实用的static方法. (1) 排序操作 reverse(List list):反转指定List集合中元素的顺序 shuffle(List li ...
- mysql对数据库的操作
增: creae database 数据库名 create database 数据库名 character set utf8; 删: drop database 数据库名 改: alter datab ...
- Python全栈开发之6、面向对象
一.创建类和对象 面向对象是一种编程方式,此编程方式的实现是基于对 类 和 对象 的使用 类是一个模板,模板中包装了多个“函数”供使用(可以讲多函数中公用的变量封装到对象中) 对象,根据模板创建的实例 ...
- [bzoj1892][bzoj2384][bzoj1461][Ceoi2011]Match/字符串的匹配_KMP_树状数组
2384: [Ceoi2011]Match 1892: Match 1461: 字符串的匹配 题目大意: 数据范围: 题解: 很巧妙的一道题呀. 需要对$KMP$算法有很深的理解才行. 首先我们需要发 ...