阅读 95

watch,computed,methods

对于Computed:

  • 它支持缓存,只有依赖的数据发生了变化,才会重新计算
  • 不支持异步,当Computed中有异步操作时,无法监听数据的变化
  • 如果computed属性的属性值是函数,那么默认使用get方法,函数的返回值就是属性的属性值;在computed中,属性有一个get方法和一个set方法,当数据发生变化时,会调用set方法。

对于Watch:

  • 它不支持缓存,数据变化时,它就会触发相应的操作
  • 支持异步监听
  • 监听的函数接收两个参数,第一个参数是最新的值,第二个是变化之前的值

    computed

    computed是计算属性,用来计算一个属性的值。

    1. 调用的时候不需要加括号,可以直接当属性来用
    2. 根据依赖自动缓存,依赖不变的时候,值不会重新计算

    computed的getter和setter

    • computed的属性可以读取和设值。因此,在computed中可以分为getter(读取)和setter(设值).
    • 一般情况下没有setter,computed只预设了getter,只能读取,不能设值。所以,computed默认格式(是不表明getter函数的).
    • 当赋值给计算属性的时候,将调用setter函数。

    watch

    watch的意思是监听,当发生变化时,监听并且执行。

    1. immediat:ture表示让值最初时候watch就执行
    2. deep表示对对象里面的变化进行深度监听
    3. 不支持缓存,数据变,直接会触发相应的操作

    如果一个值依赖多个属性(多对一),用computed肯定是更加方便的。如果一个值变化后会引起一系列操作,或者一个值变化会引起一系列值的变化(一对多),用watch更加方便一些。

    watch 支持异步代码而 computed 不支持。

原文:https://www.cnblogs.com/renhj1996/p/15308031.html

文章分类
百科问答
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐