02.Vue3组合式API·计算属性computed

目录

computed的特点

computed使用

重写computed

访问computed计算属性的上一个计算值


computed的特点

  • 计算属性具有缓存值功能,只有当依赖的属性值发生变更时,才会重新计算值,并将新的计算值存入缓存中。
    • 普通的函数总是在重新渲染时再次执行函数。
  • 计算属性应只作为计算存在,在其计算过程中,应该只提供返回值,而不要改变其他状态或更改DOM。
  • 尽量避免直接修改computed的值,除非情况特殊

computed使用

<script setup>
import { reactive, computed } from 'vue'
const author = reactive({
  name: 'John Doe',
  books: [
    'Vue 2 - Advanced Guide',
    'Vue 3 - Basic Guide',
    'Vue 4 - The Mystery'
  ]
})
// 一个计算属性 ref
// publishedBooksMessage() 会依赖author.books,一旦这个属性值发生改变,就会触发publishedBooksMessage函数值的变化
// 计算属性会把新的值存入缓存中,直至author.books下次变化
const publishedBooksMessage = computed(() => {
  return author.books.length > 0 ? 'Yes' : 'No'
})
</script>


<template>
  <p>Has published books:</p>
  <span>{{ publishedBooksMessage }}</span>
</template>

重写computed

在少部分情况下,我们会需要给计算属性重新赋值,这里我们可以通过get和set函数来解决。

<script setup>
import { ref, computed } from 'vue'
const firstName = ref('John')
const lastName = ref('Doe')
const fullName = computed({
  // getter
  get() {
    return firstName.value + ' ' + lastName.value
  },
  // setter
  // 当你运行 fullName.value = 'John Doe' 时,setter 会被调用而 firstName 和 lastName 会随之更新。
  set(newValue) {
    // 注意:我们这里使用的是解构赋值语法
    [firstName.value, lastName.value] = newValue.split(' ')
  }
})
</script>

访问computed计算属性的上一个计算值

<script setup>
import { ref, computed } from 'vue'
const count = ref(2)
// 这个计算属性在 count 的值小于或等于 3 时,将返回 count 的值。
// 当 count 的值大于等于 4 时,将会返回满足我们条件的最后一个值
// 直到 count 的值再次小于或等于 3 为止。
const alwaysSmall = computed((previous) => {
  if (count.value <= 3) {
    return count.value
  }


  return previous
})
</script>

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星夜温蓝

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值