简述Vue中的计算属性
1、什么是计算属性
- 如果模板中的表达式存在过多的逻辑,那么模板会变得臃肿不堪,维护起来也异常困难,因此为了简化逻辑出现了计算属性;
<template>
<div id="example">
<p>{{message.split(" ").reverse().join('!')}}</p>
</div>
</template>
<script>
export default {
name: "example",
data() {
return {
message : 'i am chinese person'
};
},
methods : { },
mounted(){ }
};
</script>上述表达式比较繁琐,因此我们采用计算属性实现
- 特点:在一个计算属性里可以完成各种复杂的逻辑,包括运算、函数调用等,只要最终返回一个结果就可以;
<template>
<div id="example">
<p>源数据:{{message}}</p>
<p>更改后的数据:{{changeMessage}}</p>
</div>
</template>
<script>
export default {
name: "example",
data() {
return {
message : 'i am chinese person'
};
},
computed : {
//getter方法
changeMessage : function(){//无需进行声明
return this.message.split(" ").reverse().join('!')
}
}
};
</script>结果为:

- 计算属性拥有的两个方法:getter setter 用来实现数据的双向绑定
<template>
<div id="example">
<p>给定以下三个词语组成一句话</p>
<span>{{combine}}</span>
<span>{{mom}}</span>
<span>{{dad}}</span>
<p style="padding:12px 0">答案为:{{result}}</p>
<button @click="btn">改变语句</button>
</div>
</template>
<script>
export default {
name: "example",
data() {
return {
mom: "妈妈",
dad: "爸爸",
combine: "组成了一个家"
};
},
computed: {
result : {//与不写get set方法的形式有区别
//一个计算属性的getter
get : function(){//三个值变化的时候,result的值会自动更新,也会自动更新DOM结构
return this.mom + this.dad + this.combine
},
// 一个计算属性的setter
set : function(newVal){//当设置result的时候,其他的值也会相应的发生改变
this.mom = newVal.substr(0,2);
this.dad = newVal.substr(2,2);
this.combine = newVal.substr(4)
}
}
},
methods : {
btn(){
this.result = "医生警察为人民服务"
}
}
};
</script>首次渲染结果为:

点击按钮结果为:

2、计算属性缓存(最大的特点)-----属性变化才执行getter函数,否则使用缓存 默认为true使用缓存
- 作用:如果频繁的使用计算属性,而计算属性方法中有大量的耗时操作(例如getter中循环一个大的数组以执行很多操作),会带来一些性能问题;
<template>
<div id="example">
<p>给定以下三个词语组成一句话</p>
<span>{{combine}}</span>
<span>{{mom}}</span>
<span>{{dad}}</span>
<p style="padding:12px 0">答案为:{{result}}</p>
<button @click="btn">改变语句</button>
</div>
</template>
<script>
export default {
name: "example",
data() {
return {
mom: "妈妈",
dad: "爸爸",
combine: "组成了一个家"
};
},
computed: {
result : {//与不写get set方法的形式有区别
//一个计算属性的getter
cache: true,//打开缓存
get : function(){//三个值变化的时候,result的值会自动更新,也会自动更新DOM结构
return new Date().getTime() + this.mom + this.dad + this.combine
},
// 一个计算属性的setter
set : function(newVal){//当设置result的时候,其他的值也会相应的发生改变
this.mom = newVal.substr(0,2);
this.dad = newVal.substr(2,2);
this.combine = newVal.substr(4)
}
}
},
methods : {
btn(){
this.result = "医生警察为人民服务"
}
}
};
</script>
3、使用过程中遇到的问题
- 计算属性getter不执行的场景
- 当包含计算属性的节点被移除并且模板当中其他地方没有在引用该属性时,对应的getter不会再执行;
<template>
<div id="example">
<button @click="btn">总价格的显示隐藏</button>
<p v-if="showTotal">总价格是:{{totalPrice}}</p>
</div>
</template>
<script>
export default {
name: "example",
data() {
return {
showTotal : true,
basePrice : 100,
};
},
computed: {
totalPrice : {
get : function(){
return this.basePrice * 99
}
}
},
methods: {
btn(){
this.showTotal = !this.showTotal
}
}
};
</script>在本程序中,p元素移除后,计算属性在别的地方不会再被使用,因此getter方法不会被执行;若每次都不执行,请加入缓存cache:false
- 当节点移除,其他地方使用计算属性时:
<template>
<div id="example">
<p>{{totalPrice}}</p>
<button @click="btn">总价格的显示隐藏</button>
<p v-if="showTotal">总价格是:{{totalPrice}}</p>
</div>
</template>
<script>
export default {
name: "example",
data() {
return {
showTotal : true,
basePrice : 100,
};
},
computed: {
totalPrice : {
cache : false,
get : function(){
console.log(1)
return this.basePrice * 99
}
}
},
methods: {
btn(){
this.showTotal = !this.showTotal
}
}
};
</script>每次都执行getter
- 当包含计算属性的节点被移除并且模板当中其他地方没有在引用该属性时,对应的getter不会再执行;
简述Vue中的计算属性的更多相关文章
- Vue学习之vue中的计算属性和侦听器
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Vue中的计算属性与$watch
计算属性:在模板中绑定表达式是非常便利的,但是他们实际上只用于简单的操作.模板是为了描述视图的结构.在模板中放入太多的逻辑会让模板过重且难以维护.这就是为什么vue.js将绑定表达式限制为一个表达式. ...
- Vue中的计算属性和监听器(computed 与 watch)
react中数据是单向绑定的,而vue中数据是双向绑定的.为什么? 在react中,主要是通过setState 去改变state的值:而在vue中,会自动的触发set 与get 改变属性的值. 在vu ...
- 浅谈vue中的计算属性和侦听属性
计算属性 计算属性用于处理复杂的业务逻辑 计算属性具有依赖性,计算属性依赖 data中的初始值,只有当初始值改变的时候,计算属性才会再次计算 计算属性一般书写为一个函数,返回了一个值,这个值具有依赖性 ...
- 怎样理解 Vue 中的计算属性 computed 和 methods ?
需求: 在 Vue 中, 我们可以像下面这样通过在 引号 或 双花括号 内写 js 表达式去做一些简单运算, 这是可以的, 不过这样写是不直观的, 而且在 html 中 夹杂 一些运算逻辑这种做法其实 ...
- Vue中computed(计算属性)、methods、watch的区别
实现效果:字符串的动态拼接 methods方法 html: <div id="app"> <!-- 监听到文本框数据的改变 --> <input ty ...
- Vue中的计算属性
一.什么是计算属性 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的.在模板中放入太多的逻辑会让模板过重且难以维护. 二.计算属性的用法 在一个计算属性里可以完成各种复杂的逻辑,包括运算.函 ...
- Vue中computed计算属性
话不多说,使用方法直接上代码//在模板中调用computedTest这个函数,切记不要在函数后添加()<template> <div class="home"&g ...
- vue中computed计算属性与methods对象中的this指针
this 指针问题 methods与computed中的this指针 应该指向的是它们自己,可是为什么this指针却可以访问data对象中的成员呢? 因为new Vue对象实例化后data中的成员和c ...
随机推荐
- 编写第一个Qt程序
http://c.biancheng.net/view/1817.html 学习一种编程语言或编程环境,通常会先编写一个“Hello World”程序.我们也用 Qt Creator 编写一个“Hel ...
- spring security There was an unexpected error (type=Forbidden, status=403).
https://blog.csdn.net/qq_27093097/article/details/83190240 spring security There was an unexpected e ...
- 1--面试总结-js深入理解,对象,原型链,构造函数,执行上下文堆栈,执行上下文,变量对象,活动对象,作用域链,闭包,This
参考一手资料:http://dmitrysoshnikov.com/ecmascript/javascript-the-core/中文翻译版本:https://zhuanlan.zhihu.com/p ...
- Linux架构--------Rsync守护进程推和拉
一.Rsync基本概述 rsync是一款开源.快速.多功能.可实现全量及增量的本地或远程数据同步备份的优秀工具.rsync软件适用于Unix/linux/Windows等多种操作系统平台. 二.Rsy ...
- ubuntu16.04 安装mysql
安装mysql 1.sudo apt-get install mysql-server 2.sudo apt install mysql-client 3.sudo apt install libmy ...
- webstorm 点击右上角运行run 启动vue项目
点击右上角框 -> 编辑结构 点击加号 新增一个npm项目 前提:node环境已经安装完成,npm包管理器 1.进行定位到项目的路径2.安装依赖包,npm install3.启动服务,npm r ...
- css语法以及css选择器
CSS语法 CSS的标准语法主要由两方面构成一是 选择器.二是 声明框. 一.选择器 通过选择器可以选定页面指定的元素,并将声明块中的样式应用在选择器选中的元素中去. 二.声明框 ...
- ng-template、ng-content、ng-container
https://www.jianshu.com/p/0f5332f2bbf8 ng-template.ng-content.ng-container三者应该是自定义组件需要经常用到的指令.今天咱们就来 ...
- mysql NOT NULL约束 语法
mysql NOT NULL约束 语法 作用:约束强制列不接受 NULL 值. 东莞大理石平台 说明:NOT NULL 约束强制字段始终包含值.这意味着,如果不向字段添加值,就无法插入新记录或者更新记 ...
- Layer Cake cf
Layer Cake time limit per test 6 seconds memory limit per test 512 megabytes input standard input ou ...