每日一博 | 你知道,什么时候用 Vue 计算属性吗?
摘要:当我们处理复杂逻辑时,都应该使用计算属性。
本文分享自华为云社区《深入理解计算属性,知道什么时候该用Vue计算属性吗?》,作者: 前端老实人 。
计算属性
有些时候,我们在模板中放入了过多的逻辑,从而导致模板过重,且难以维护。例如:
<div id="app"> {{ message.split('').reverse().join('') }} </div>
碰到这样的情况,我们必须看一段时间才能意识到,这里是想要显示变量message的翻转字符串,而且,一旦我们想要在模板中多次使用翻转字符串时,会更加麻烦。 所以,当我们处理复杂逻辑时,都应该使用计算属性。
基础用法
计算属性是Vue配置对象中的属性,使用方式如下:
<div id="app"> <!-- 计算属性的值可以像data数据一样,直接被使用 --> {{ someComputed }} </div> const vm = new Vue({ el: '#app', computed: { // 返回的值,就是计算属性的值 someComputed () { return 'some values' } } })
例如,我们想要获取到一串字符串的翻转字符串,我们可以利用计算属性来做:
<div id="app"> <p>原始字符串: "{{ msg }}"</p> <p>翻转字符处啊: "{{ reversedMsg }}"</p> </div> const vm = new Vue({ el: '#app', data: { msg: 'Hello' }, computed: { reversedMsg: function () { return this.msg.split('').reverse().join(''); } } })
我们可以看到,reversedMsg的值取决于msg的值,所以,当我们更改msg的值是,reversedMsg的值也会随之更改。
计算属性 vs 方法
其实,我们上述的功能,利用方法也可以实现,如:
<div id="app"> <p>原始字符串: "{{ msg }}"</p> <p>翻转字符串: "{{ reversedMsg() }}"</p> </div> const vm = new Vue({ el: '#app', data: { msg: 'Hello' }, methods: { reversedMsg: function () { return this.msg.split('').reverse().join(''); } } })
虽然在表达式中调用方法也可以实现同样的效果,但是使用计算属性和使用方法有着本质的区别。 当使用方法时,每一次页面重新渲染,对应的方法都会重新执行一次,如:
<div id="app"> <p>{{ name }}</p> <p>{{ reversedMsg() }}</p> </div> const vm = new Vue({ el: '#app', data: { msg: 'Hello', name: 'shanshan' }, methods: { reversedMsg: function () { console.log('方法执行啦'); return this.msg.split('').reverse().join(''); } } }) vm.name = 'duyi';
在上面的例子中我们可以看到,一旦更改name的值,页面会重新渲染,此刻控制台中打印出方法执行啦这串字符串,代表着reversedMsg这个函数执行了,但是我们并不需要该方法执行,因为改动的数据和这个函数没有任何关系,如果这个函数内的逻辑很复杂,那么对于性能来讲,也是一种消耗。
但是利用计算属性做,就不会有这样的现象出现,如:
const vm = new Vue({ el: '#app', data: { msg: 'Hello', name: 'shanshan' }, computed: { reversedMsg: function () { console.log('计算执行啦'); return this.msg.split('').reverse().join(''); } } }) vm.name = 'duyi';
此时可以看到,当给数据name重新赋值时,计算属性并没有执行。 所以,计算属性和方法的最本质的区别,是:计算属性是基于响应式依赖进行缓存的,计算属性的值一直存于缓存中,只要它依赖的data数据不改变,每次访问计算属性,都会立刻返回缓存的结果,而不是再次执行函数。而方法则是每次触发重新渲染,调用方法将总会再次执行函数。
那么,为什么需要缓存呢?
假如说,我们有一个计算属性A,它需要遍历一个巨大的数组并且做巨大的计算。然后我们需要使用到这个计算属性A,如果没有缓存,我们就会再次执行A的函数,这样性能开销就变得很大了。
深入计算属性
计算属性除了写成一个函数之外,还可以写成一个对象,对象内有两个属性,getter&setter,这两个属性皆为函数,写法如下:
const vm = new Vue({ el: '#app', computed: { fullName: { getter () { // 一些代码 }, setter () { // 一些代码 } } } })
getter 读取
在前面,我们直接将计算属性写成了一个函数,这个函数即为getter函数。也就是说,计算属性默认只有getter。 getter的this,被自动绑定为Vue实例。
何时执行?
当我们去获取某一个计算属性时,就会执行get函数。
const vm = new Vue({ el: '#app', data: { msg: 'Hello' }, computed: { reversedMsg: { getter () { return this.msg.split('').reverse().join(''); } } } })
setter 设置
可选,set函数在给计算属性重新赋值时会执行。 参数:为被重新设置的值。 setter的this,被自动绑定为Vue实例。
const vm = new Vue({ el: '#app', data: { msg: 'Hello', firstStr: '' }, computed: { reversedMsg: { getter () { return this.msg.split('').reverse().join(''); }, setter (newVal) { this.firstStr = newVal[0]; } } } })
要注意,即使给计算属性赋了值,计算属性也不会改变,在重复一遍,只有当依赖的响应式属性变化了,计算属性才会重新计算。
练习_姓名筛选
personArr: [ { name: '', src: '.jpg', des: '颈椎不好', sex: 'm', id: '056482' }, { name: '', src: '.jpg', des: '我是谁', sex: 'f', id: '157894' }, { name: '', src: '.jpg', des: '我长得很好看', sex: 'f', id: '2849245' }, { name: '', src: '.jpeg', des: '你没有见过陌生的脸', sex: 'm', id: '348515' }, { name: '', src: '.jpeg', des: '瓜皮刘', sex: 'm', id: '478454' } ],
练习_全选商品
courseList: [ { poster: '.jpg', title: '', price: 1299, cart: 1, id: 0 }, { poster: '.jpg', title: '', price: 1148, cart: 1, id: 1595402664708 }, { poster: '.jpg', title: '', price: 1, cart: 1, id: 1596305473062 }, { poster: '.jpg', title: '', price: 1, cart: 1, id: 1595413512182 }, { poster: '.jpg', title: '', price: 12798, cart: 1, id: 1596302161181 }, { poster: '.jpg', title: '', price: 1, cart: 1, id: 1596300025301, }, ]

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
一流科技与摩尔线程深度合作,共同加速人工智能创新和应用
近日,一流科技与摩尔线程宣布将携手展开深度技术合作,基于摩尔线程国产全功能GPU的计算能力及一流科技OneFlow深度学习框架的高效特性,为AI应用提供更高效的计算性能。摩尔线程GPU将为OneFlow提供高性能算力支持,助力提升AI用户体验,共同打造更好的AI 行业解决方案。在此基础上,双方还将共建共享生态,助力中国人工智能行业发展。 深度学习是近年兴起的人工智能研究方向,企业进行深度学习模型的训练和部署时离不开深度学习框架及硬件基础设施。深度学习框架素有人工智能操作系统之称,对深度学习模型的设计和应用具有决定性影响,而高性能的计算芯片则为深度学习框架提供强有力的算力支撑。 近年来,得益于深度学习框架和高性能计算芯片的发展,深度学习展现出极大的革命性,推动人工智能在一些领域率先落地并取得广泛应用,例如语音识别、机器视觉、自然语言处理等。 随着社会数字化进程的推进,数据规模呈现爆炸式增长,深度学习神经网络模型的规模也越来越大,超大模型的训练、推理对算力提出了更高的需求。几年前,一流科技团队预见到深度学习模型变大的发展趋势,基于这个趋势倒推系统架构的需求,在行业内最早提出了静态调度和流式...
- 下一篇
instantbox —— 临时的 Linux 系统环境搭建
instantbox 可以让你快速的搭建一个临时的 Linux 系统,并可以通过基于浏览器的 webshell 来访问这个系统。 instantbox 能做什么? 提供一个干净的用于演示的 Linux 环境 可以在教学中为学生提供实操 Linux 环境 在一个干净的系统中验证灵感 可以从很多设备上执行服务器管理工作 体验一个开源的项目 测试软件性能
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Docker安装Oracle12C,快速搭建Oracle学习环境
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- 2048小游戏-低调大师作品
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- SpringBoot2全家桶,快速入门学习开发网站教程
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- MySQL8.0.19开启GTID主从同步CentOS8
- Hadoop3单机部署,实现最简伪集群