vue计算属性怎么实现
Vue 计算属性的实现方法
计算属性(Computed Properties)是 Vue 中用于处理复杂逻辑的响应式数据属性。其特点是基于依赖的缓存机制,只有当依赖发生变化时才会重新计算。
基本语法
在 Vue 组件中通过 computed 选项定义计算属性:
export default {
data() {
return {
firstName: '张',
lastName: '三'
}
},
computed: {
fullName() {
return this.firstName + ' ' + this.lastName
}
}
}
计算属性 vs 方法
计算属性与方法的区别在于缓存机制:
- 方法:每次调用都会执行函数
- 计算属性:依赖不变时直接返回缓存值
methods: {
getFullName() {
return this.firstName + ' ' + this.lastName
}
}
计算属性的 setter
计算属性默认只有 getter,需要时可提供 setter:
computed: {
fullName: {
get() {
return this.firstName + ' ' + this.lastName
},
set(newValue) {
const names = newValue.split(' ')
this.firstName = names[0]
this.lastName = names[names.length - 1]
}
}
}
计算属性的缓存特性
计算属性会根据它们的响应式依赖进行缓存,只有在相关依赖发生改变时才会重新求值:
computed: {
now() {
return Date.now() // 不会更新,因为不是响应式依赖
}
}
在模板中使用
计算属性在模板中可以像普通属性一样使用:
<template>
<div>{{ fullName }}</div>
</template>
计算属性的最佳实践
- 避免在计算属性中做异步操作或修改DOM
- 复杂的计算逻辑适合放在计算属性中
- 需要响应式处理的数据关系使用计算属性
- 对于简单的显示逻辑,可以直接在模板中使用表达式
计算属性是 Vue 响应式系统的核心特性之一,合理使用可以提升应用性能和代码可维护性。







