![](https://csdnimg.cn/release/download_crawler_static/87502596/bg4.jpg)
没有的话,仅仅把 this.dirty = true。 (当计算属性依赖于其他数据时,属性并不
会立即重新计算,只有之后其他地方需要读取属性的时候,它才会真正计算,
即具备 lazy(懒计算)特性。)
3. computed 和 watch 有什么区别及运用场景?
区别
computed 计算属性 : 依赖其它属性值,并且 computed 的值有缓存,只有它依
赖的属性值发生改变,下一次获取 computed 的值时才会重新计算 computed
的值。
watch 侦听器 : 更多的是「观察」的作用,无缓存性,类似于某些数据的监听回
调,每当监听的数据变化时都会执行回调进行后续操作。
运用场景
运用场景:
当我们需要进行数值计算,并且依赖于其它数据时,应该使用 computed,因为可
以利用 computed 的缓存特性,避免每次获取值时,都要重新计算。
当我们需要在数据变化时执行异步或开销较大的操作时,应该使用 watch,使用
watch 选项允许我们执行异步操作 ( 访问一个 API ),限制我们执行该操作的
频率,并在我们得到最终结果前,设置中间状态。这些都是计算属性无法做到的。
4. 为什么在 Vue3.0 采用了 Proxy,抛弃了
Object.defineProperty?