computed和watch区别
1、从名字上,computed是计算属性,也就是依赖其它的属性计算所得出最后的值。watch是去监听一个值的变化,然后执行相对应的函数。computed是用于定义基于数据之上的数据,而watch是你想在某个数据变化时做一些事情。
2、实现上,computed的值在getter执行后是会缓存的,只有在它依赖的属性值改变之后,下一次获取computed的值时才会重新调用对应的getter来计算。watch在每次监听的值变化时,都会执行回调。其实从这一点来看,都是在依赖的值变化之后,去执行回调。很多功能本来就很多属性都可以用,只不过有更适合的。如果一个值依赖多个属性(多对一),用computed肯定是更加方便的。如果一个值变化后会引起一系列操作,或者一个值变化会引起一系列值的变化(一对多),用watch更加方便一些。
3、watch的回调里面会传入监听属性的新旧值,通过这两个值可以做一些特定的操作。computed通常就是简单的计算。
4、watch和computed并没有哪个更底层,watch内部调用的是vm.$watch,它们的共同之处就是每个定义的属性都单独建立了一个Watcher对象。
5、使用上,如果一个数据依赖于其他数据,那么把这个数据设计为computed的;如果你需要在某个数据变化时做一些事情,使用watch来观察这个数据变化
6、当需要在数据变化时执行异步或开销较大的操作时,这个方式是最有用的。

本文深入探讨了Vue中computed和watch的区别与应用场景。从计算属性与监听器的基本概念出发,详细阐述了两者在实现机制、性能优化及使用场景上的不同。通过具体案例,帮助读者理解何时使用computed更高效,何时采用watch更合适。
1303

被折叠的 条评论
为什么被折叠?



