0


【Vue】Vue中的计算属性computed

CSDN话题挑战赛第2期
参赛话题:面试宝典

💭💭

✨: 计算属性computed

💟:东非不开森的主页

💜:如果有幸和你一起学习一起进步,那就太棒啦💜💜

计算属性computed

一、计算属性computed

1.1.什么是计算属性computed

⭐⭐
computed 是基于它的依赖缓存,只有在它的相关依赖发生改变时才会进行更新。官方文档是这样说的:对于任何包含响应式数据的复杂逻辑,你都应该使用计算属性

1.2.复杂数据的处理-computed

⭐⭐
拼接字符串、分数是否及格、message记录一段文字,这里是用computed实现的

<div id="app"><!-- 插值语法表达式直接进行拼接 --><!--1.拼接姓名 --><h2>{{fullname}}</h2><!--2.显示分数及格或不及格 --><h2>{{scorelevel}}</h2><!--3.反转单词 --><!-- reverse针对于数组,先用split转为数组,在用reverse --><h2>{{reversetext}}</h2></div><script src="../lib/vue.js"></script><script>const app = Vue.createApp({data(){return{// namefirstName:"kk",lastName:"cc",// scorescore:99,// 文本中单词反转message:"I love stydy Vue3",};},computed:{fullname(){returnthis.firstName +" "+this.lastName;},scorelevel(){returnthis.score >=60?"及格":"不及格";},reversetext(){returnthis.message.split(" ").reverse().join(" ");},},});
      app.mount("#app");

当然我们用Mustache插值语法、methods也是可以完成的,但是对于复杂数据的处理,我们往往采用computed,写法更清晰,且计算属性是有缓存的

1.3.计算属性的缓存

⭐⭐

  • 会基于它们的依赖关系进行缓存;
  • 在数据不发生变化时,计算属性是不需要重新计算的;
  • 但是如果依赖的数据发生变化,在使用时,计算属性依然会重新进行计算;

&tinsp;
所以这也是我们在复杂数据处理时更倾向于computed

  • 在使用相同次数的fullName时,methods执行三次,computed执行一次,这正是由于computed计算属性会被缓存在这里插入图片描述在这里插入图片描述

1.4.计算属性computed的setter和getter

⭐⭐
大多数情况下,计算属性只需要一个getter方法,那么此时computed属性属性值为函数
如果想要设置计算属性的值,我们可以给计算属性设置一个setter方法

computed:{// 语法糖fullname(){returnthis.firstname +" "+this.lastname;},// 完整写法fullname:{get:function(){returnthis.firstname +" "+this.lastname;},set:function(value){const names = value.split(" ");this.firstname = names[0];this.lastname = names[1];},},

本文转载自: https://blog.csdn.net/m0_62159662/article/details/127186464
版权归原作者 东非不开森 所有, 如有侵权,请联系我们删除。

“【Vue】Vue中的计算属性computed”的评论:

还没有评论