Vue中的watch是如何实现深度监听的?

简介: Vue中的watch是如何实现深度监听的?

在 Vue 中,可以使用watch选项来监听数据的变化。如果需要深度监听对象中的数据变化,可以使用deep: true选项。例如:

<template>
  <div>
    <input type="text" v-model="obj.a" @input="handleInput" />
    <input type="text" v-model="obj.b" @input="handleInput" />
    <p>{
   {
    obj }}</p>
  </div>
</template>

<script>
export default {
   
  data() {
   
    return {
   
      obj: {
    a: '', b: '' },
    };
  },
  watch: {
   
    obj: {
   
      handler(newValue, oldValue) {
   
        console.log('obj changed:', newValue, oldValue);
      },
      deep: true,
    },
  },
  methods: {
   
    handleInput(event) {
   
      this.obj[event.target.name] = event.target.value;
    },
  },
};
</script>

在上述示例中,我们使用watch选项监听obj对象的变化。当obj对象中的任何一个属性发生变化时,都会触发handler函数。同时,我们使用deep: true选项开启深度监听,这样当obj对象中的子属性发生变化时,也会触发handler函数。

目录
相关文章
|
7天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
51 1
|
17天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
缓存 JavaScript
vue中computed和watch的区别
vue中computed和watch的区别
|
缓存 JavaScript
Vue 中 computed 和 watch 的区别
Vue 中 computed 和 watch 的区别
97 0
|
8月前
|
缓存 JavaScript
聊一聊Vue中的computed和watch区别
聊一聊Vue中的computed和watch区别
|
8月前
|
缓存 JavaScript
Vue 中的 computed 和 watch 的区别
Vue 中的 computed 和 watch 的区别
|
缓存 JavaScript 前端开发
Vue 中的 computed 和 watch 的区别
Vue 中的 computed 和 watch 的区别
227 0

热门文章

最新文章