vue3计算属性
1. 使用计算属性来描述依赖响应式状态的复杂逻辑
<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
const publishedBooksMessage = computed(() => {
return author.books.length > 0 ? 'Yes' : 'No'
})
</script>
<template>
<p>Has published books:</p>
<span>{{ publishedBooksMessage }}</span>
</template>
//1.computed()方法接收到的是一个ref,所以可以通过publishedBooksMessage.value访问
//2.当author.books 改变时,publishedBooksMessage的值也会更新
2. 上面这段代码也可以使用方法来完成,但是方法和计算属性有一个重大区别
计算属性会缓存,只有值改变时才会更新(也就是author.books
改变时,publishedBooksMessage的值才会变,不然一直返回之前计算的结果)
但是方法不会缓存,所以每一次重新渲染时都会重新执行一次,很耗性能
3. 计算属性是只读的,只有在特殊场景才会去改变它的值
<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
set(newValue) {
// 注意:我们这里使用的是解构赋值语法
[firstName.value, lastName.value] = newValue.split(' ')
}
})
</script>
//当你再运行 fullName.value = 'John Doe' 时,setter 会被调用而 firstName 和 lastName 会随之更新。
4. 可以使用计算属性返回上一个值
<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>