在 Vue 3 中,计算属性(computed properties)是一种基于依赖项动态计算并缓存的响应式数据。它与 Vue 2 中的计算属性类似,但在组合式 API 中使用 computed
函数来定义。计算属性的核心优势在于能够自动缓存计算结果,仅在依赖的数据发生变化时重新计算,避免了重复计算和性能浪费。
1. 计算属性的用法
基本用法
在组合式 API 中,可以通过 computed
函数创建计算属性。computed
接受一个回调函数作为参数,回调函数的返回值会成为计算属性的值。
import { ref, computed } from 'vue';
const count = ref(1);
const doubleCount = computed(() => count.value * 2);
console.log(doubleCount.value); // 输出:2
count.value = 2;
console.log(doubleCount.value); // 输出:4
可写计算属性
计算属性默认是只读的,但也可以定义一个可写的计算属性,允许通过 set
函数改变其值。可写计算属性接受一个对象形式的参数,该对象包含 get
和 set
函数。
const count = ref(1);
const doubleCount = computed({
get: () => count.value * 2,
set: (newValue) => {
count.value = newValue / 2;
}
});
doubleCount.value = 10; // 触发 setter,count.value 会被设为 5
console.log(count.value); // 输出:5
2. 计算属性的使用场景
1. 数据依赖的逻辑处理
-
计算属性常用于处理基于多个响应式数据的复杂计算逻辑。例如在电商购物车中,可以用计算属性计算商品的总价、折扣价格、优惠数量等。
const cartItems = ref([
{ name: 'Product A', price: 100, quantity: 2 },
{ name: 'Product B', price: 50, quantity: 3 },
]);const totalPrice = computed(() =>
cartItems.value.reduce((total, item) => total + item.price * item.quantity, 0)
);console.log(totalPrice.value); // 输出:350
2. 表单中的动态显示数据
-
计算属性在动态表单中也很常用。例如在用户填写信息时,显示实时计算的表单反馈(例如字数统计、动态预览等)。
const firstName = ref('');
const lastName = ref('');
const fullName = computed(() =>${firstName.value} ${lastName.value}
);firstName.value = 'John';
lastName.value = 'Doe';
console.log(fullName.value); // 输出:'John Doe'
3. 条件和状态的控制
-
计算属性可以用于处理复杂的状态和条件。例如在页面上根据多个条件计算出是否显示某个按钮、图标或提示。
const isLoggedIn = ref(true);
const hasAdminRights = ref(false);const canAccessSettings = computed(() => isLoggedIn.value && hasAdminRights.value);
console.log(canAccessSettings.value); // 输出:false
4. 避免重复计算和优化性能
- 计算属性可以缓存复杂的计算结果,避免在不必要的时候重新计算。例如,如果计算内容是一个大量数据的过滤或排序操作,使用计算属性可以减少性能开销。
3. 计算属性 vs. 方法 vs. 侦听器
- 计算属性:具有缓存机制,只有当依赖的数据发生变化时才会重新计算,适用于数据依赖的动态展示。
- 方法(methods):每次调用都会重新计算,因此不具备缓存特性。适用于不依赖数据的、仅在用户触发时才执行的逻辑。
- 侦听器(watch):适用于监听数据变化并触发副作用,例如数据提交、API 请求等。
总结
计算属性在 Vue 3 中是一种强大的工具,特别适合用于基于响应式数据的逻辑计算、动态显示、条件控制等场景。相比其他方法,计算属性的缓存机制可以有效优化性能,是开发 Vue 应用时的核心工具。