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>
相关推荐
硬汉嵌入式几秒前
QEMU & FFmpeg作者Fabrice Bellard推出MicroQuickJS,一款面向嵌入式系统JavaScript引擎,仅需10K RAM
javascript·ffmpeg·microquickjs
GitCode官方5 分钟前
DevUI 组织 2025 年度运营报告:扎根 AtomGit,开源前端再启新程
前端·开源·atomgit
恋猫de小郭7 小时前
Flutter 正在计划提供 Packaged AI Assets 的支持,让你的包/插件可以更好被 AI 理解和选择
android·前端·flutter
小小前端--可笑可笑7 小时前
Vue / React 单页应用刷新 /login 无法访问问题分析
运维·前端·javascript·vue.js·nginx·react.js
小林敲代码77888 小时前
记一次 Vue 项目首屏优化:从 7.1s 到 0.9s,深挖 Gzip 的力量
前端·javascript·vue.js
前端大卫8 小时前
写给年轻程序员的几点小建议
前端
Highcharts.js8 小时前
什么是向量图表?如何用 Highcharts 快速创建一个笛卡尔坐标图/矢量图?
javascript·开发文档·highcharts·图表开发·向量图·矢量图表·笛卡尔坐标图
NEXT069 小时前
React 闭包陷阱深度解析:从词法作用域到快照渲染
前端·react.js·面试
脱离语言9 小时前
Jeecg3.8.2 前端经验汇总
开发语言·前端·javascript
NEXT069 小时前
useMemo 与 useCallback 的原理与最佳实践
前端·javascript·react.js