前端经典面试题 | Vue的computed 和 watch的区别

简介: 前端经典面试题 | Vue的computed 和 watch的区别

一、回答点

侦听 响应变化 属性


computed是模版表达式的声明式描述,会创建一个新的响应式数据.而watch是响应式数据的自定义侦听器,用于响应数据的变化.computed具有缓存性及可依赖多个属性,getter函数没不良作用等特点.watch更适合异步或开销大的操作.


总结:


      computed计算属性:依赖其他属性值,computed有缓存,只有它依赖的值发生改变,下次获取computed的值时才会重新计算它.


      watch侦听器:更多的是起到了观察的作用,无缓存.类似于某数据的监听回调,每当数据发生变化时,就会执行回调进行之后的操作.

二、深入回答

1.实现原理

       computed等同于为属性设置getter函数(也可以设setter),而watch等同于为属性的setter设置回调函数,监听深度deep及相应速度immediate


      1.1 computed原理(四阶段)


      初始化阶段:为computed属性创建lazy watcher (这里watch指向双向绑定中的监听器.)


      模版渲染阶段:渲染watcher检测到computed属性时,调用computed属性的getter方法,而computed属性的getter方法会调用依赖属性的getter,而形成链式调用,并保存引用关系来进行之后的更新.取得结果后,lazy watcher将结果进行缓存,并返回给渲染watcher进行模版的渲染.


      多次模版渲染阶段:直接取lazy watcher中的缓存值给渲染watcher进行渲染


      依赖属性更新阶段:根据模版渲染阶段构建的依赖关系(链式调用)向上通过lazy watcher进行重新计算,缓存计算结果并通过 渲染watcher 对页面进行重新渲染


        1.2 watch原理


       watch本质是为每个监听属性的setter创建了一个watcher,当被监听的数据更新时,调用传入的回调函数.常见的参数有:deep和immediate,对应原理如下:


     deep:深度监听对象,为对象的每个属性创建一个watcher 确保对象的每个属性更新时都会触发传入的回调函数. 主要在于 对象属于引用类型,单个属性的更新并不会触发对象的setter,因此引入deep能够更好的解决监听对象的问题.同时也引入判断机制,在多个属性更新时回调函数仅触发一次,避免浪费资源.


      immediate:在初始化时直接调用回调函数,可以通过created阶段,手动进行调用回调函数实现相同效果

2.适用场景

       当需要进行数值计算,并依赖于其他数据时,使用computed,因为可以利用computed的缓存特性,避免每次获取值都要重新进行计算


       当需要在数据变化时执行异步或开销大的操作时,使用watch,使用watch选项运行执行异步操作,限制执行该操作的频率,并在拿到最终的结果前,设置中间状态.

相关文章
|
18天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
18天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
26天前
|
存储 缓存 网络协议
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点,GET、POST的区别,Cookie与Session
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点、状态码、报文格式,GET、POST的区别,DNS的解析过程、数字证书、Cookie与Session,对称加密和非对称加密
|
1月前
|
缓存 前端开发 JavaScript
"面试通关秘籍:深度解析浏览器面试必考问题,从重绘回流到事件委托,让你一举拿下前端 Offer!"
【10月更文挑战第23天】在前端开发面试中,浏览器相关知识是必考内容。本文总结了四个常见问题:浏览器渲染机制、重绘与回流、性能优化及事件委托。通过具体示例和对比分析,帮助求职者更好地理解和准备面试。掌握这些知识点,有助于提升面试表现和实际工作能力。
64 1
|
2月前
|
JavaScript 前端开发 开发者
Vue v-for 进阶指南:in 与 of 的区别及应用场景 | 笔记
Vue.js 中的 v-for 是强大的遍历指令,但其中的 in 和 of 关键字往往被开发者忽视。尽管它们的用法相似,但适用的场景和数据结构却各有不同。本文将详细探讨 v-for 中 in 和 of 的区别、适用场景以及在实际开发中的最佳使用时机。通过理解它们的差异,你将能够编写更加高效、简洁的 Vue.js 代码,灵活应对各种数据结构的遍历需求。
90 6
|
2月前
|
缓存 JavaScript
Vue 中 computed 与 method 的区别
【10月更文挑战第15天】computed 和 method 是 Vue 中两个重要的选项,它们在功能和特点上存在着明显的区别。理解并合理运用它们的区别,可以帮助我们构建更高效、更具可维护性的 Vue 应用。在实际开发中,要根据具体情况灵活选择使用,以满足不同的需求。
24 2
|
2月前
|
缓存 JavaScript
|
2月前
|
JavaScript
vue3,使用watch监听props中的数据
【10月更文挑战第3天】
1281 2
|
2月前
|
缓存 JavaScript Serverless
vue中computed计算属性、watch侦听器、methods方法的区别以及用法
vue中computed计算属性、watch侦听器、methods方法的区别以及用法
118 0
|
2月前
|
前端开发 小程序 JavaScript
面试官:px、em、rem、vw、rpx 之间有什么区别?
面试官:px、em、rem、vw、rpx 之间有什么区别?
48 0