vue中computed和watch

Vue 中的computed和watch

场景:假设我们有一个简单的购物车应用,需要计算购物车中商品的总价。

在这个例子中:

  • 使用v-model指令绑定了两个输入字段,一个是"数量"(quantity),另一个是"单价"(unitPrice)。
  • 我们定义了一个computed属性totalAmount,用于计算购物车的总价,它依赖于quantityunitPrice这两个数据属性。当quantityunitPrice变化时,totalAmount会自动重新计算。
  • 我们还使用watch来监视quantity的变化。当quantity变化时,会触发watch中的函数,这里我们简单地打印出了变化的信息。

这个例子中,computed用于派生数据,计算购物车的总价,而watch用于在quantity变化时执行自定义操作。这样就展示了它们的不同用途。

html 复制代码
<!DOCTYPE html>
<html>
<head>
  <title>Vue.js Shopping Cart</title>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
</head>
<body>
  <div id="app">
    <input v-model="quantity" type="number" placeholder="数量">
    <input v-model="unitPrice" type="number" placeholder="单价">
    <p>总价: {{ totalAmount }}</p>
  </div>

  <script>
    var app = new Vue({
      el: '#app',
      data: {
        quantity: 0,
        unitPrice: 0
      },
      computed: {
        totalAmount: function() {
          return this.quantity * this.unitPrice;
        }
      },
      watch: {
        quantity: function(newQuantity, oldQuantity) {
          console.log('Quantity changed from ' + oldQuantity + ' to ' + newQuantity);
          // 在这里你可以执行任何自定义操作,比如发送购物车数量变化的日志或向服务器发起请求。
        }
      }
    });
  </script>
</body>
</html>
相关推荐
赛博切图仔4 分钟前
深入理解 package.json:前端项目的 “身份证“
前端·javascript
UIUV8 分钟前
JavaScript 学习笔记:深入理解 map() 方法与面向对象特性
前端·javascript·代码规范
玉宇夕落15 分钟前
深入剖析 JavaScript 中 map() 与 parseInt 的“经典组合陷阱”
javascript·面试
太平洋月光17 分钟前
MJML邮件如何随宽度变化动态切换有几列📮
前端·css
AAA不会前端开发19 分钟前
TypeScript核心类型系统完全指南
前端·typescript
徐同保23 分钟前
使用GitKraken把feature_xtb_1104分支的多次提交记录合并到一起,只保留一次提交记录,并合并到master分支
前端
小光学长31 分钟前
基于Vue的智慧楼宇报修平台设计与实现066z15wb(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
醉方休39 分钟前
web前端 DSL转换技术
前端
sen_shan39 分钟前
Vue3+Vite+TypeScript+Element Plus开发-27.表格页码自定义
前端·javascript·typescript
刺客_Andy1 小时前
React 第五十二节 Router中 useResolvedPath使用详解和注意事项示例
前端·react.js·架构