1. vue3计算属性以及赋值
<template>
<!-- 计算属性比如分页器就会使用到 -->
<h1>计算属性</h1>
<!-- 此时obj.hobby.length是大于0的,所以页面的list为yes -->
<h3>{{ list }}</h3>
<button @click="getList">获取list的值 ==>{{ val }}</button>
</template>
<script setup>
import {ref, reactive, computed } from "vue";
const obj = reactive({
todo: '吃饭',
hobby: ['打篮球', '打乒乓球', '踢足球']
})
const val = ref(null)
const list = computed(() => {
return obj.hobby.length > 0 ? "yes" : 'no'
})
const getList = () => {
console.log(list.value);
val.value = list.value
}
</script>
2. 计算属性是只读的
- 当你尝试修改一个计算属性时,你会收到一个运行时警告。只在某些特殊场景中你可能才需要用到“可写”的属性,你可以通过同时提供 getter 和 setter 来创建:
<script setup>
import { ref, computed } from 'vue'
const firstName = ref('John')
const lastName = ref('Doe')
const fullName = computed({
get() {
return firstName.value + ' ' + lastName.value
},
set(newValue) {
[firstName.value, lastName.value] = newValue.split(' ')
}
})
</script>
- 现在再运行 fullName.value = ‘John Doe’ 时,setter 会被调用而 firstName 和 lastName 会随之更新
总结
- 计算属性值会基于其响应式依赖被缓存。(这意味着只要
obj.hobby
不改变,无论多少次访问 list 都会立即返回先前的计算结果,而不用重复执行 getter 函数。) - 计算属性默认是只读的。