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、当需要在数据变化时执行异步或开销较大的操作时,这个方式是最有用的。