vue中computed和watch

一、computed和method的区别

1我们可以把同一个函数定义为一个方法method而不是计算属性computed,两种方式最后的结果是一样的;

2.不同的是,计算属性computed是基于他们的依赖进行缓存的,只有相关依赖的值发生改变才会重新求值(因为它会对已经计算过的结果进行缓存),当它所依赖的值没有发生改变时,我们访问这个计算属性他会立即出现结果;

3而方法Method只要被触发就会再次执行该函数,会重新求值,

相比之下,每当触发重新渲染时,调用方法将总会再次执行函数。

4.如果我们不希望有缓存,就用method来代替。

二、computed和watch区别

类型是否被缓存备注
computed只要依赖值有变化就会立马执行
method需要绑定事件

很多情况下,我们会选择使用computed而不去用watch,但是当我们需要在数据变化时执行异步或者开销比较大的情况下,此时选用watch(官网所述)

类型目的备注
computed依赖变动时更新数据更新数据
watch观察某一特定的值,执行特定的函数观察数据

computed,是一个计算的属性,类似过滤器,对数据进行处理后return一个新的state,并且可以监听该返回值的变化;

watch是监听数据变化,可以调用其他方法或者做一些事情,它是一个动作;

大多数情况下我们会选择使用computed,因为它会进行缓存:

我们为什么需要缓存?假设我们有一个性能开销比较大的的计算属性 A,它需要遍历一个巨大的数组并做大量的计算。然后我们可能有其他的计算属性依赖于 A 。如果没有缓存,我们将不可避免的多次执行 A 的 getter!

在什么情况下使用watch?进行异步请求

data: {
    firstName: 'Foo',
    lastName: 'Bar'
  },
  computed: {
    fullName: function () {
      return this.firstName + ' ' + this.lastName
    }
  }//computed用法
 data: {
    firstName: 'Foo',
    lastName: 'Bar',
    fullName: 'Foo Bar'
  },
  watch: {
     firstName: function (val) {
     this.fullName = val + ' ' + this.lastName
    },
  lastName: function (val) {
     this.fullName = this.firstName + ' ' + val
    }
  }//watch用法

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值