computed 和 watch 的区别是什么?

  • 当我们需要从data的数据中,经过一系列的操作,得到一条新数据,同时不改变data中的原数据时,可以使用computed 计算属性,watch一般用于侦听data或props数据的变化
  • 只要是computed能完成的功能,watch就可以完成;watch能完成的,computed不一定能完成
  • computed不支持异步,无法监听异步操作数据的变化;watch可以进行异步操纵
  • computed支持缓存,只有依赖数据发生改变,才会重新进行计算; watch不支持缓存,数据变,直接会触发相应的操作
  • computed 属性值会默认走缓存,计算属性是基于它们的响应式依赖进行缓存的,也就是基于data中声明过或者父组件传递的props中的数据通过计算得到的值
  • computed 如果一个属性是由其他属性计算而来的,这个属性依赖其他属性,是一个多对一或者一对一,一般用computed
  • 当一个属性发生变化时,需要执行对应的操作;一对多的操作使用 watch
  • 如果computed属性属性值是函数,那么默认会走get方法;函数的返回值就是属性的属性值;在computed中的,属性都有一个get和一个set方法,当数据变化时,调用set方法。
  • watch监听的函数接收两个参数,第一个参数是最新的值;第二个参数是输入之前的值;
  • watch监听数据必须是data中声明过或者父组件传递过来的props中的数据,当数据变化时,触发其他操作,函数有两个参数,

  immediate:组件加载立即触发回调函数执行,

  deep: 深度监听,为了发现对象内部值的变化,复杂类型的数据时使用,例如数组中的对象内容的改变

  • 当需要在数据变化时执行异步或开销较大的操作时,建议使用watch
上一篇:Vue前端面试题目——watch、computed、methods有什么区别


下一篇:Vue在页面数据渲染完成之后的调用方法--类似实现jq的ready方法