vue watch监听

在 Vue.js 中,watch 是一个对象,用于观察和响应 Vue 实例上的数据变化。当被监视的属性发生变化时,watch 里的回调函数将被调用。

(vue2)官方文档:计算属性和侦听器 --- Vue.js (vuejs.org)

下面是一个简单的 watch 示例:

javascript 复制代码
<template>  
  <div>  
    <input v-model="message" placeholder="输入一些文字...">  
    <p>{{ message }}</p>  
  </div>  
</template>  
  
<script>  
export default {  
  data() {  
    return {  
      message: ''  
    };  
  },  
  watch: {  
    // 监听 message 属性的变化  
    message(newVal, oldVal) {  
      console.log(`新的 message 值是: ${newVal}`);  
      console.log(`旧的 message 值是: ${oldVal}`);  
    }  
  }  
};  
</script>

在这个例子中,当 message 的值发生变化时,watch 里的回调函数将被调用,并打印出新旧的值。

你还可以使用深度监听对象或数组的变化,只需在 watch 选项中将属性设置为一个对象,并设置 deep 属性为 true

javascript 复制代码
<template>  
  <div>  
    <input v-model="userInfo.name" placeholder="输入名字...">  
    <p>{{ userInfo.name }}</p>  
  </div>  
</template>  
  
<script>  
export default {  
  data() {  
    return {  
      userInfo: {  
        name: ''  
      }  
    };  
  },  
  watch: {  
    userInfo: {  
      handler(newVal, oldVal) {  
        console.log(`新的 userInfo 值是:`, newVal);  
        console.log(`旧的 userInfo 值是:`, oldVal);  
      },  
      deep: true // 深度监听  
    }  
  }  
};  
</script>

在这个例子中,当 userInfo 对象的 name 属性发生变化时,watch 里的回调函数将被调用,并打印出新旧的值。

此外,还可以使用 immediate 属性,使得 watch 在初始化时立即执行一次回调函数:

javascript 复制代码
watch: {  
  message: {  
    handler(newVal, oldVal) {  
      console.log(`新的 message 值是: ${newVal}`);  
      console.log(`旧的 message 值是: ${oldVal}`);  
    },  
    immediate: true // 初始化时立即执行  
  }  
}

在这个例子中,watch 在初始化时将立即执行一次回调函数,打印出 message 的初始值。

更多请看其他大佬文章:

Vue.js 监听属性 | 菜鸟教程 (runoob.com)

Vue进阶(三十五):watch 监听函数详解 - 掘金 (juejin.cn)

Vue之watch监听的原理_vue watch原理-CSDN博客

vue的watch监听_vue watch监听-CSDN博客

vue-watch监听功能(侦听器)详解&使用_vue watch监听-CSDN博客

相关推荐
大模型玩家七七13 分钟前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习
. . . . .21 分钟前
shadcn组件库
前端
2501_9447114329 分钟前
JS 对象遍历全解析
开发语言·前端·javascript
发现一只大呆瓜1 小时前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
css趣多多1 小时前
ctx 上下文对象控制新增 / 编辑表单显示隐藏的逻辑
前端
阔皮大师1 小时前
INote轻量文本编辑器
java·javascript·python·c#
lbb 小魔仙1 小时前
【HarmonyOS实战】React Native 表单实战:自定义 useReactHookForm 高性能验证
javascript·react native·react.js
_codemonster1 小时前
Vue的三种使用方式对比
前端·javascript·vue.js
寻找奶酪的mouse1 小时前
30岁技术人对职业和生活的思考
前端·后端·年终总结
梦想很大很大2 小时前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go