如何更好地理解 Vue 3 watch 侦听器的用法

🤍 前端开发工程师、技术日更博主、已过CET6

🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1

🕠 牛客 高级专题作者、打造专栏《前端面试必备》《2024面试高频手撕题》

🍚 蓝桥云课 签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》《带你从入门到实战全面掌握 uni-app》

文章目录

标题:🕵️‍♀️

摘要:

本文将介绍Vue 3中watch侦听器的多种用法和案例,以及它在实际开发中的应用。

引言:

在Vue 3中,watch侦听器用于监听数据的变化,并在数据变化时执行相应的操作。了解watch侦听器的用法和案例对于Vue开发者来说具有重要意义。

正文:

1. watch的基本用法🔧

在 Vue 3 中,watch 函数是一个非常有用的工具,用于在数据变化时执行一些操作。以下是一些基本的用法:

  1. 创建一个 refreactive 对象来存储需要监听的数据。
javascript 复制代码
import { ref, watch } from 'vue';

export default {
  setup() {
    const count = ref(0);
    const message = ref('Hello, Vue 3!');

    // ...
  }
};
  1. 使用 watch 函数来监听数据的变化。watch 函数接收两个参数:一个是要监听的数据的引用,另一个是当数据发生变化时要调用的回调函数。
javascript 复制代码
import { ref, watch } from 'vue';

export default {
  setup() {
    const count = ref(0);
    const message = ref('Hello, Vue 3!');

    watch(count, (newValue, oldValue) => {
      console.log(`Count changed from ${oldValue} to ${newValue}`);
    });

    watch(message, (newValue, oldValue) => {
      console.log(`Message changed from ${oldValue} to ${newValue}`);
    });

    // ...
  }
};
  1. 如果需要在数据变化时执行异步操作,可以将回调函数设置为 async
javascript 复制代码
import { ref, watch } from 'vue';

export default {
  setup() {
    const count = ref(0);

    async function increment() {
      count.value++;
      await fetchData();
    }

    watch(count, async (newValue, oldValue) => {
      console.log(`Count changed from ${oldValue} to ${newValue}`);
    });

    // ...
  }
};
  1. 如果需要在数据变化时执行一个函数,但不需要记录旧值和新值,可以将第二个参数设置为 true
javascript 复制代码
import { ref, watch } from 'vue';

export default {
  setup() {
    const count = ref(0);

    function increment() {
      count.value++;
    }

    watch(count, increment, { deep: true });

    // ...
  }
};

这些示例展示了如何在 Vue 3 中使用 watch 函数来监听数据的变化。通过这些示例,你可以更好地理解 watch 函数的用法。

2. watch的多种用法🌟

watch侦听器具有多种用法,以下是一些常见的用法:

  • 监听基本数据类型:用于监听基本数据类型的变化;
  • 监听对象和数组:用于监听对象和数组的变化;
  • 监听函数:用于监听函数的变化;
  • 监听多个数据:用于同时监听多个数据的变化。

3. watch的案例🌐

在实际开发中,watch侦听器可以用于多种场景,以下是一些典型的案例:

  1. 使用 watch 侦听器监听数据变化,制作一个动态标题生成器
html 复制代码
<template>
  <div>
    <input v-model="title" placeholder="输入标题" />
    <h1>{{ title }}</h1>
  </div>
</template>

<script>
import { ref, watch } from 'vue';

export default {
  setup() {
    const title = ref('');

    watch(title, (newVal, oldVal) => {
      console.log(`标题从 "${oldVal}" 变为 "${newVal}"`);
    });

    return {
      title
    };
  }
};
</script>
  1. 使用 watch 侦听器监听数据变化,实现一个动态背景颜色切换器
html 复制代码
<template>
  <div :style="{ backgroundColor: bgColor }">
    <button @click="changeBgColor">切换背景颜色</button>
  </div>
</template>

<script>
import { ref, watch } from 'vue';

export default {
  setup() {
    const bgColor = ref('');

    watch(bgColor, (newVal, oldVal) => {
      console.log(`背景颜色从 "${oldVal}" 变为 "${newVal}"`);
    });

    function changeBgColor() {
      bgColor.value = bgColor.value === 'red' ? 'blue' : 'red';
    }

    return {
      bgColor,
      changeBgColor
    };
  }
};
</script>
  1. 使用 watch 侦听器监听数据变化,实现一个动态加载图片的标题
html 复制代码
<template>
  <div>
    <input v-model="imageUrl" placeholder="输入图片URL" />
    <img :src="imageUrl" alt="动态图片" />
  </div>
</template>

<script>
import { ref, watch } from 'vue';

export default {
  setup() {
    const imageUrl = ref('');

    watch(imageUrl, (newVal, oldVal) => {
      console.log(`图片URL从 "${oldVal}" 变为 "${newVal}"`);
    });

    return {
      imageUrl
    };
  }
};
</script>

这些示例展示了如何使用 Vue 3 的 watch 侦听器监听数据变化,实现动态标题生成器、动态背景颜色切换器和动态加载图片的标题。通过这些示例,你可以更好地理解 watch 侦听器的用法。

总结:

Vue 3中的watch侦听器用于监听数据的变化,并在数据变化时执行相应的操作。了解watch侦听器的多种用法和案例对于Vue开发者来说具有重要意义。掌握watch侦听器的使用可以帮助我们更高效地处理数据变化。

参考资料:

本文详细介绍了Vue 3中watch侦听器的多种用法和案例,以及它在实际开发中的应用。希望对您有所帮助。如有疑问或建议,请随时与我交流。📧🎉

相关推荐
葡萄城技术团队26 分钟前
如何通过前端表格控件实现自动化报表?1
运维·前端·自动化
CharlesYu0126 分钟前
vite作者如何评价turbopack
前端·turbopack
小王码农记33 分钟前
vue中动态绑定ref后,获取某个具体组件实例
前端·javascript·vue.js
悲且狂1 小时前
vue辅助工具(vue系列二)
前端·javascript·vue.js
牧码岛1 小时前
Web前端之Vue+Element实现表格动态不同列合并多行、localeCompare、forEach、table、push、sort、Map
前端·javascript·elementui·vue·web·web前端
老K(郭云开)1 小时前
如何让eDrawings html文件在Chrome浏览器上展示——allWebPlugin中间件扩展
前端·javascript·chrome·中间件·edge·html
DCTANT2 小时前
【原创】vue-element-admin-plus完成确认密码功能,并实时获取Form中表单字段中的值
前端·javascript·vue.js·elementui·typescript
汪子熙2 小时前
使用 Trae 开发一个演示勾股定理的动画演示
前端·人工智能·trae
GISer_Jing2 小时前
字符串操作&栈和队列
前端·javascript
黑土豆3 小时前
TypeScript技术系列13:深入理解配置文件tsconfig.json
前端·javascript·typescript