VueVue中的计算属性computed
Posted 东非不开森
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了VueVue中的计算属性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
// name
firstName: "kk",
lastName: "cc",
// score
score: 99,
// 文本中单词反转
message: "I love stydy Vue3",
;
,
computed:
fullname()
return this.firstName + " " + this.lastName;
,
scorelevel()
return this.score >= 60 ? "及格" : "不及格";
,
reversetext()
return this.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()
return this.firstname + " " + this.lastname;
,
// 完整写法
fullname:
get: function ()
return this.firstname + " " + this.lastname;
,
set: function (value)
const names = value.split(" ");
this.firstname = names[0];
this.lastname = names[1];
,
,
以上是关于VueVue中的计算属性computed的主要内容,如果未能解决你的问题,请参考以下文章
12 计算属性computed: 当计算属性依赖的内容发生变更时,才会重新执行计算
vue.js中的计算属性(computed)methodswatched三者的区别
VueVue入门--双向绑定,Vue的组件,Axios异步通信,计算属性,插值,自定义事件