简述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 ...
随机推荐
- MongoDB入门_MongoDB安装与配置
MongoDB运行环境 MongoDB环境:CentOS-6.7-i386 MongoDB版本:MongoDB 2.6.5 ssh工具:xshell 文本编辑工具:vim与editplus++ 编译M ...
- 几个有关FPGA的概念
<数字设计——原理和实践>(John F.Wakerly)的书 FPGA同步时钟设计 简单说就是 一个系统中(或系统中的一部分)都采用同一个时钟触发.系统中的(D)触发器全部都连接到一个时 ...
- UVa10426
GCD Extreme(II) Input: Standard Input Output: Standard Output Given the value of N, you will have to ...
- Python核心技术与实战——十一|程序的模块化
我们现在已经总结了Python的基本招式和套路,现在可以写一些不那么简单的系统性工程或代码量较大的应用程序.这时候,一个简单的.py文件就会显得过于臃肿,无法承担一个重量级软件开发的重任.这就需要这一 ...
- 线段树维护区间前k小
线段树维护区间前k小 $ solution: $ 觉得超级钢琴太麻烦?在这里线段树提供一条龙服务 . 咳咳,开始讲正题!这道题我们有一个和超级钢琴复杂度一样 $ ~O(~\sum x\times lo ...
- 花式赋值、列表、字典、解压缩、input()、格式化学习笔记
目录 花式赋值 列表(list) 字典(dict) 解压缩 input()与用户交互 格式化的三种方式 f_String格式化(important) %s.%d占位符 format 格式化(不常用) ...
- react native之使用 Fetch进行网络数据请求
这是一个单独的页面,可以从其他地方跳转过来. 输入语言关键字,从github检索相关数据 import React, {Component} from 'react'; import { StyleS ...
- POJ 1252 Euro Efficiency ( 完全背包变形 && 物品重量为负 )
题意 : 给出 6 枚硬币的面值,然后要求求出对于 1~100 要用所给硬币凑出这 100 个面值且要求所用的硬币数都是最少的,问你最后使用硬币的平均个数以及对于单个面值所用硬币的最大数. 分析 : ...
- Codeforces 878A - Short Program(位运算)
原题链接:http://codeforces.com/problemset/problem/878/A 题意:给出n个位运算操作, 化简这些操作, 使化简后的操作次数不多于5步. 思路:我们可以对二进 ...
- SpringBoot整合knife4j
官网说明及用法: 简介 swagger-bootstrap-ui是springfox-swagger的增强UI实现,为Java开发者在使用Swagger的时候,能拥有一份简洁.强大的接口文档体验 核心 ...