Vue 侦听器

Vue中提供了一种特定功能,可以监听一个受控制的变量(data选项中声明的变量)内部的数据是否发生更新,一旦发生更新就**可以被监听(自动执行)**并执行一些后续的操作!

基本语法:

const app = new Vue({
    ....
    watch: {
    	被监听的变量: function(oldVal, newVal) {
    		当变量中的数据一旦发生改变,自动执行的函数
		}
	}
})

代码操作:

<!DOCTYPE html>
<html lang="zh">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <div id="app">
    <p>普通变量:{{ message }}</p>
    <p>对象数据:{{ loginForm.username }}</p>
  </div>

  <script src="./vue.js"></script>
  <script>
    const app = new Vue({
      el: "#app",
      data: {
        message: "变量数据",
        loginForm: {
          username: 'damu'
        }
      },
      watch: {
        // 普通变量,简介语法声明的监听器
        message: (newVal, oldVal) => {
          console.log(newVal, oldVal,  "监听器生效")
        },
        // 对象数据,完整语法,声明的深度监听器
        loginForm: {
          handler(newVal, oldVal){
            console.log(newVal.username, oldVal.username, "对象监听器生效")
          },
          deep: true  // 开启深度监听,可以监听对象内部的数据是否发生变化
        }
      }
    })
  </script>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值