Vue.js深入理解:Watch与Computed的运用解析
版权申诉
8 浏览量
更新于2024-07-07
收藏 18KB DOCX 举报
Vue.js 是一个流行的前端框架,它的核心特性之一就是响应式数据绑定。在 Vue 应用中,`watch` 和 `computed` 是两个重要的概念,它们分别用于数据变化的监听和计算属性的管理。
### 01. 监听器 `watch`
**(1)作用**
`watch` 用于监控 Vue 实例中的数据属性,当这些属性发生变化时,它会执行预定义的回调函数。这使得开发者可以在数据变化时执行相应的逻辑,比如数据同步、异步请求或者复杂的业务处理。
**(2)属性和方法**
- `handler`: 这是回调函数,当被监听的属性变化时执行。
- `immediate`: 如果设置为 `true`,组件创建后立即触发一次回调。
- `deep`: 如果设置为 `true`,将深度监听对象或数组的所有嵌套属性。
**(3)监听对象**
监听整个对象时,`handler` 函数会接收到新旧对象的完整副本。然而,它不会监听对象内新增或删除的属性,只有在直接修改已存在的属性时才会触发。
**(4)监听数组**
默认情况下,Vue 只能监听数组的 `push`, `pop`, `shift`, `unshift`, `splice`, `sort`, `reverse` 方法,如果需要监听数组内元素的变动,需要开启 `deep` 属性。
### 02. 计算属性 `computed`
**(1)计算属性的 `set` 方法**
计算属性默认只有 getter,但可以通过定义 `set` 方法来实现设置功能。当在模板中尝试更改计算属性时,Vue 将调用 `set` 方法并将新的值作为参数传递。
```javascript
export default {
data() {
return {
number: 1
}
},
computed: {
computedNumber: {
get() {
return this.number * 2
},
set(value) {
this.number = value / 2
}
}
}
}
```
在上面的例子中,当尝试改变 `computedNumber` 时,Vue 会调用 `set` 方法,将新的值除以 2 并赋给 `number`。
**(2)区别**
- `watch` 是主动监听数据变化并执行回调,而 `computed` 是被动的,仅在依赖的数据变化时重新计算结果。
- `computed` 的结果会被缓存,只有依赖变化时才更新,而 `watch` 每次数据变化都会触发。
**(3)使用场景**
- 当需要基于现有数据生成衍生数据时,使用 `computed`,如计算总和、过滤列表等。
- 当需要在数据变化时执行复杂逻辑或副作用操作时,如发送请求、更新 DOM,使用 `watch`。
通过理解 `watch` 和 `computed` 的差异和用法,开发者可以更有效地组织和优化 Vue 应用中的数据处理逻辑。在实际开发中,合理运用它们可以帮助提高代码的可读性和性能。
2021-12-29 上传
2021-12-29 上传
2020-10-18 上传
点击了解资源详情
点击了解资源详情
点击了解资源详情
点击了解资源详情
mmoo_python
- 粉丝: 4263
- 资源: 1万+
最新资源
- 火炬连体网络在MNIST的2D嵌入实现示例
- Angular插件增强Application Insights JavaScript SDK功能
- 实时三维重建:InfiniTAM的ros驱动应用
- Spring与Mybatis整合的配置与实践
- Vozy前端技术测试深入体验与模板参考
- React应用实现语音转文字功能介绍
- PHPMailer-6.6.4: PHP邮件收发类库的详细介绍
- Felineboard:为猫主人设计的交互式仪表板
- PGRFileManager:功能强大的开源Ajax文件管理器
- Pytest-Html定制测试报告与源代码封装教程
- Angular开发与部署指南:从创建到测试
- BASIC-BINARY-IPC系统:进程间通信的非阻塞接口
- LTK3D: Common Lisp中的基础3D图形实现
- Timer-Counter-Lister:官方源代码及更新发布
- Galaxia REST API:面向地球问题的解决方案
- Node.js模块:随机动物实例教程与源码解析