computed与watch的区别

本文详细解析了Vue中computed和watch的区别,包括computed主要根据返回值计算,不支持异步操作,而watch可以监测变化并执行异步任务。同时,介绍了在编写Vue函数时关于this指针的注意事项,普通函数适用于被Vue管理的场景,箭头函数则确保在非Vue管理的异步回调中正确绑定this。示例代码展示了如何在watch中处理姓名的变更以更新全名。
摘要由CSDN通过智能技术生成
  <!--
		computed和watch之间的区别:
				1.computed能完成的功能,watch都可以完成。
				2.watch能完成的功能,computed不一定能完成,例如:watch可以进行异步操作。
                3.computed主要根据return来得到返回值,所以没有定时器。
                4.watch主要是自己监测改变值,所以可以添加定时器。
                两个重要的小原则:
				1.所被Vue管理的函数,最好写成普通函数,这样this的指向才是vm 或 组件实例对象。
				2.所有不被Vue所管理的函数(定时器的回调函数、ajax的回调函数等、Promise的回调函数),最好写成箭头函数,
				这样this的指向才是vm 或 组件实例对象。
	-->
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>vue计算属性语法实现</title>
    <script src="../js/vue.js"></script>
  </head>
  <body>
    <div id="root">
      :<input type="text" v-model="firstName" /> <br /><br />
      :<input type="text" v-model:value="lastName" /> <br /><br />
      全名: <span>{{ fullName }}</span>
    </div>
    <script type="text/javascript">
      const vm = new Vue({
        el: "#root",
        data: {
          //data里的都是属性
          firstName: "张",
          lastName: "三",
          fullName: "张-三",
        },
        watch: {
          //这里不需要深度监视则简写 监视firstname lastname
          //计算属性不能开启异步操作更新
          firstName(val) {
            //this === vm
            setTimeout(() => {
              //箭头函数没有this继承外部作用域的this
              //定时器由js模块调用,所以函数写成箭头函数
              //如果写成function(){}的形式 this === window,则无法更新watch属性
              this.fullName = val + "-" + this.lastName;
            }, 1000);
          },
          lastName(val) {
            this.fullName = this.firstName + "-" + val;
          },
        },
      });
    </script>
  </body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值