在Vue中什么情况用computed,watch,methods理解

本文深入探讨Vue.js中data, computed, methods和watch的作用与区别。通过实例讲解如何使用这些特性来优化应用性能,包括实时监听数据变化、生成新属性及缓存策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

根据原本的例子,补充自己的一点想法,整理如下:

用一个例子来说明一下吧:

<div id="demo">
  <p>message: "{{ message }}"</p>
  <p>reversed message: "{{ reversedMessage }}"</p>
  <button @click="add">add</button>
  <p>点击次数:{{num}}</p>
</div>

var vm = new Vue({
  el: '#demo',
  data: {
    message : 'abcde',
    num: 0
  },
  watch: {
    // 监听数据的变化做出对应的改变,并不会生成新的属性
    num (newVal) {
        if (newVal > 5) this.alert()
    }
  },
  methods: {
    alert () {
      alert('点击次数达到'+this.num+'次啦')
    },
    add () {
      this.num += 1
    }
  },
  computed: { 
    // 根据原有值生成一个新的属性值
    reversedMessage () {
      return this.message.split('').reverse().join('')
    }
  }
})

methods: 存放的方法是一些内部方法、事件的回调、命令是调用的方法。
watch: 用于监听数据的实时的变化。在数据变化的回调中执行异步操作或者开销很大的时候使用。
computed: 也是实时监听数据变化,做出相应的变化,跟watch不同的是他可以被看成一个data里面的属性值来使用。所以当我们需要监听一个值并且需要生成一个新的属性时就可以使用computed

cumputed vs methods

有些时候computedmethods可以完成同样的事情,但是computed是基于它们的依赖进行缓存的,而methods需要每次去计算。

 <p>reversed message: "{{ reversedMessage() }}"</p>

{
  methods: {
    reversedMessage () {
       return this.message.split('').reverse().join('')
    }
  }
}

computed只有在他依赖的数据发生变化时才会求值。依赖不发生改变,每次访问computed应该是之前的计算结果。
也就是说需要缓存的话可以使用computed来实现,不需要的话可以用其他方式代替。

cumputed vs watch

官方的例子

<div id="demo">{{ fullName }}</div>
// 用watch实现
var vm = new Vue({
  el: '#demo',
  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
    }
  }
})
// 用computed实现
var vm = new Vue({
  el: '#demo',
  data: {
    firstName: 'Foo',
    lastName: 'Bar'
  },
  computed: {
    fullName: function () {
      return this.firstName + ' ' + this.lastName
    }
  }
})

很明显computed实现起来更简洁更方便也更容易理解。
当你有一些数据需要随着其它数据变动而变动时,你很容易滥用 watch。然而,通常更好的想法是使用计算属性而不是命令式的 watch 回调。

直观看:

computed监听的是function里面涉及的变量,并且生成冒号前面的新变量的值。 

 

 

watch监听的是冒号前面的变量值,执行的是function里面的操作。

computed 的 setter 和 getter

默认情况下 只有 getter,不过在需要时你也可以提供一个 setter

computed: {
  fullName: {
    // getter
    get: function () {
      return this.firstName + ' ' + this.lastName
    },
    // setter
    set: function (newValue) {
      var names = newValue.split(' ')
      this.firstName = names[0]
      this.lastName = names[names.length - 1]
    }
  }
}

现在再运行 vm.fullName = 'John Doe' 时,setter 会被调用,vm.firstName 和 vm.lastName 也相应地会被更新。

虽然计算属性在大多数情况下更合适,但有时也需要一个自定义的 watcher。这是为什么 Vue 通过 watch 选项提供一个更通用的方法,来响应数据的变化。当你想要在数据变化响应时,执行异步操作或开销较大的操作,这是很有用的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值