【VUE】Vue中 computed计算属性和watch侦听器的区别

核心功能不同

computed 是一个计算属性,其核心功能是基于已有的数据属性计算得出新的属性值。当某个依赖的数据发生变化时,computed 会自动重新计算并更新自己的值。因此,可以将 computed 看做是一种"派生状态"。

watch 是一个观察者函数(watcher),可以监听某个数据的变化并执行回调函数。当被监听的数据变化时,watch 将会被触发并执行与之相关的回调函数。watch 的核心功能是"响应式",它可以对数据变化做出响应。

使用场景不同

computed 适用于那些需要根据已有数据计算得出新值的情况,例如:对列表进行过滤、格式化日期等。

computed 的特点是:响应式、缓存和计算结果只有在相关依赖发生变化时才进行更新。

因此,如果一个属性需要频繁计算,又与其他属性有关联,那么使用 computed 可以有效提高应用的性能。

watch 适用于那些需要在数据变化时采取特定操作的情况,例如:异步操作、API 调用等。

watch 的特点是:监听数据变化、执行回调函数并且可以拿到新旧值。

响应式的原理不同

computed 依赖于响应式系统的更新机制,当计算属性所依赖的数据发生变化时,会自动触发重新计算。

因此,computed 是一种响应式依赖关系。

watch 使用了 Vue 的观察者机制,底层实现是通过 Object.defineProperty() 来设置 getter 和 setter 函数,并在数据变化时触发回调函数。

因此,watch 基于的是"事件监听",而不是响应式依赖关系。

相关推荐
岁月宁静44 分钟前
MasterGo AI 实战教程:10分钟生成网页设计图(附案例演示)
前端·aigc·视觉设计
狗头大军之江苏分军1 小时前
快手12·22事故原因的合理猜测
前端·后端
我命由我123451 小时前
CSS 锚点定位 - 锚点定位引入(anchor-name、position-anchor)
开发语言·前端·javascript·css·学习·html·学习方法
哟哟耶耶1 小时前
js-清除首尾空白字符再进行空白匹配str.trim().match(...)
开发语言·前端·javascript
计算机毕设VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue医院挂号管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
亚林瓜子2 小时前
nodejs里面的百分号解码之URLSearchParams
开发语言·javascript·ecmascript·node·url·百分号编码
南山安2 小时前
React学习:通过TodoList,完整理解组件通信
javascript·react.js·前端框架
浮游本尊2 小时前
React 18.x 学习计划 - 第十天:React综合实践与项目构建
前端·学习·react.js
阿蔹2 小时前
UI测试自动化--Web--Python_Selenium-元素定位
前端·ui·自动化
万少2 小时前
【鸿蒙心迹】-03-自然壁纸实战教程-项目结构介绍
前端