往期内容:
Vue零基础必学教程(5)挂载
Vue零基础必学教程(6)基本选项
Vue零基础必学教程(7)模板
Vue零基础必学教程(8)模板语法
Vue零基础必学教程(9)插值语法细节
Vue零基础必学教程(10)属性绑定指令
Vue零基础必学教程(11)事件绑定指令
Vue零基础必学教程(12)双向绑定指令
Vue零基础必学教程(13) 条件渲染
Vue零基础必学教程(14) 列表渲染
Vue零基础必学教程(15) 样式绑定
1) 什么是计算属性
计算属性就是基于现有属性计算后的属性
2) 计算属性的作用
计算属性用于对原始数据的再次加工
3) 案例
需求
实现如下效果
使用表达式实现
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.js"></script></head><body><!-- 需求: 实现字符串的反转eg. abc 转换成 cba --><div id="app">请输入一个字符串: <input type="text" v-model="msg" /> <br /><!-- 反转字符串的思路1. 取出字符串中的每个字符 msg.split('') 形成一个数组2. 反转数据. msg.split('').reverse() 形成一个反转数组3. 将反转数组拼接. msg.split('').reverse().join('')--><!-- 不推荐!! 在模板中书写复杂的表达式 --><h3>反转后的字符串: {{msg.split('').reverse().join('')}}</h3></div><script>const vm = new Vue({el: '#app',data: {msg: '',},})</script></body>
</html>
使用方法实现
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.js"></script></head><body><!-- 需求: 实现字符串的反转eg. abc 转换成 cba --><div id="app">请输入一个字符串: <input type="text" v-model="msg" /> <br /><!-- 反转字符串的思路1. 取出字符串中的每个字符 msg.split('') 形成一个数组2. 反转数据. msg.split('').reverse() 形成一个反转数组3. 将反转数组拼接. msg.split('').reverse().join('')--><!-- 不推荐使用方法原因: 没有缓存, 每次调用方法, 代码会执行一次--><h3>反转后的字符串: {{reverseMsg()}}</h3><h3>反转后的字符串: {{reverseMsg()}}</h3><h3>反转后的字符串: {{reverseMsg()}}</h3><h3>反转后的字符串: {{reverseMsg()}}</h3><h3>反转后的字符串: {{reverseMsg()}}</h3></div><script>const vm = new Vue({el: '#app',data: {msg: '',},methods: {reverseMsg() {console.log('反转函数被执行了...')// 返回 反转后的字符串return this.msg.split('').reverse().join('')},},})</script></body>
</html>
使用计算属性实现
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><script src="../node_modules/vue/dist/vue.js"></script></head><body><!-- 需求: 实现字符串的反转eg. abc 转换成 cba --><div id="app">请输入一个字符串: <input type="text" v-model="msg" /> <br /><!-- 反转字符串的思路1. 取出字符串中的每个字符 msg.split('') 形成一个数组2. 反转数据. msg.split('').reverse() 形成一个反转数组3. 将反转数组拼接. msg.split('').reverse().join('')--><!-- 推荐使用 计算属性1. 有缓存的. 当计算属性生成一次后, 挂载到vm实例. 后继的访问, 直接使用vm实例上的属性2. 方便调试--><h3>反转后的字符串: {{reverseMsg}}</h3><h3>反转后的字符串: {{reverseMsg}}</h3><h3>反转后的字符串: {{reverseMsg}}</h3><h3>反转后的字符串: {{reverseMsg}}</h3><h3>反转后的字符串: {{reverseMsg}}</h3></div><script>const vm = new Vue({el: '#app',data: {msg: '',},computed: {// 编写一个函数, 这个函数会被做为该计算属性的getterreverseMsg() {console.log('计算属性被执行了...')// 该函数的返回值, 做为访问计算属性的结果return this.msg.split('').reverse().join('')},},})</script></body>
</html>
4) 特点
- 有缓存
- 调试方便