您当前的位置:首页 > 计算机 > 编程开发 > JavaScript

在 Vue 中的监听器与计算属性

时间:12-14来源:作者:点击数:
CDSY,CDSY.XYZ

Vue的 watch()函数 可以起到与 计算属性 。 例如,假设您要跟踪用户购物车中的商品数量。 你可以代表 numItems 作为计算属性:

const app = new Vue({
  data: () => ({ items: [{ id: 1, price: 10, quantity: 2 }] }),
  computed: {
    numItems: function numItems() {
      return this.items.reduce((sum, item) => sum + item.quantity, 0);
    }
  },
  template: `<div>numItems is {{numItems}}</div>`
});

您还可以定义一个观察者来更新 numItems 每次都有财产 items 变化:

const app = new Vue({
  data: () => ({
    items: [{ id: 1, price: 10, quantity: 2 }],
    numItems: 2
  }),
  watch: {
    items: function updateNumItems() {
      this.numItems = this.items.reduce((sum, item) => sum + item.quantity, 0);
    }
  },
  template: `<div>numItems is {{numItems}}</div>`
});

您应该使用哪种方法? 通常,您应该使用计算属性来更新值。 您应该只将观察者用于“副作用”,例如 console.log(),或 HTTP 请求。 这就是为什么。

保持同步更新

问题与 numItems作为观察者,您可能会意外更新 numItems不更新 items. 这意味着 numItems可能不同步。

const app = new Vue({
  data: () => ({
    items: [{ id: 1, price: 10, quantity: 2 }],
    numItems: 2
  }),
  watch: {
    items: function updateNumItems() {
      this.numItems = this.items.reduce((sum, item) => sum + item.quantity, 0);
    }
  },
  methods: {
    myMethod: function() {
      // Perfectly valid, since `numItems` is a data property.
      this.numItems = 5;
    }
  },
  template: `<div>numItems is {{numItems}}</div>`
});

另一方面,如果您尝试更新计算属性,Vue 会将其视为无操作并打印以下警告:

[Vue warn]: Computed property "numItems" was assigned to but it has no setter.

所以 numItems保证与内容保持同步 items,即使您不小心尝试覆盖它。

何时使用观察者

当 您想要执行异步操作以响应不断变化的数据 。 例如,如果您想自动保存 cart 每次更改时,您可能会执行以下操作:

const app = new Vue({
  data: () => ({
    items: [{ id: 1, price: 10, quantity: 2 }],
  }),
  watch: {
    items: async function saveCart() {
      await axios.put('/cart', items);
    }
  },
  template: ...
});
CDSY,CDSY.XYZ
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门
本栏推荐