管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异

本文主要是介绍管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、侦听器(watch)是什么?

二、Vue2中的watch(Options API)

2.1、函数式写法

2.2、对象式写法

        ①对象式基础写法

        ②回调函数handler

        ③deep属性

        ④immediate属性

三、Vue3中的watch

3.1、向下兼容(Vue2)的Options API

3.2、使用Composition API

3.2.1、基础语法

3.2.2、基础用法示例

3.2.3、Vue3中的对象式写法

四、Vue3中的watchEffect

五、总结


一、侦听器(watch)是什么?

        侦听器是一个在 Vue.js 框架中用于观察和响应数据变化的机制。侦听器允许开发者指定一个函数,这个函数会在特定数据变化时自动执行。Vue.js 使用侦听器来实现数据双向绑定和响应式更新。

        说简单点,侦听器常用来监听数据的变化,并在数据变化时捕获数据变化前后的值,并执行我们声明的回调函数。

        就像现实中的监听设备一样,发现情况有变立马行动,只不过Vue中的侦听器只针对数据。

二、Vue2中的watch(Options API)

        在Vue2中,watch 是一个选项,你可以在组件中定义它来观察数据的变化。常用的包括函数式写法和对象式写法,以我个人的习惯,如果监听的需求比较简单, 也不会涉及到日后的拓展问题,就可以直接使用函数式,这样写起来简便;如果监听比较复杂,比如监听有多层的对象,或者需要用到immediate属性,又或者要方便日后拓展和维护,就用对象式,这样更清晰,更方便拓展。还有就是大型项目建议还是用对象式,统一用法比较好。

2.1、函数式写法

        此时每个被侦听的属性被当做一个“函数”,这个函数就是被侦听的属性变化后所执行的回调函数,该函数接受两个参数,第一个是变化后的新值,第二个是变化前的旧值。

export default {data() {return {watchedProperty: ''};},watch: {// 当 watchedProperty 发生变化时,这个函数将被调用watchedProperty(newVal, oldVal) {// 在这里执行当 watchedProperty 改变时要执行的代码console.log(`从 ${oldVal} 变为 ${newVal}`);}}
};

2.2、对象式写法

        ①对象式基础写法

        此时每个被侦听的属性被当做一个“对象”,这个对象名就是被侦听的属性名,该对象中有一个函数和若干个属性。基础写法如下:

export default {data() {return {dataProperty: ''};},watch: {// 观察 dataProperty 的变化dataProperty: {// 当 dataProperty 发生变化时,这个函数将被调用handler(newVal, oldVal) {console.log(`数据从 ${oldVal} 变更为 ${newVal}`);},// 深度观察deep: true,// 立即执行观察者函数immediate: true}}
};

        ②回调函数handler

        对象式写法中有个函数名为handler,名称不可自定义,该函数为被监听属性变化后所执行的回调函数,该函数接受两个参数,第一个是变化后的新值,第二个是变化前的旧值。

        ③deep属性

        deep是常用的属性:缺省值为false,只监听表层变化,设置为true后可监听深层的数值,deep选项允许你观察对象内部属性的变化。如果没有设置deep,当对象内部的属性变化时,handler函数不会被触发。见下方例子:

export default {data() {return {userInfo: {name: 'John Doe',age: 30}};},watch: {userInfo: {handler(newVal, oldVal) {console.log(`用户信息从 ${JSON.stringify(oldVal)} 变更为 ${JSON.stringify(newVal)}`);},deep: true}}
};

        在这个例子中,如果userInfo对象的name或age属性发生变化,handler函数将被调用,因为它使用了deep选项,但如果没有设置deep,那么只有在userInfo引用的内容发生变化时才会调用handler函数,比如将另外一个对象直接浅拷贝给userInfo。

        ④immediate属性

        immediate选项允许你在开始观察时立即执行handler函数。这一般是用在需要组件初始化时就立即执行handler函数的情况下。下面是一个例子:

export default {data() {return {initialData: 'Initial Value'};},watch: {initialData: {handler(newVal, oldVal) {console.log(`初始数据从 ${oldVal} 变更为 ${newVal}`);},immediate: true}},created() {// 组件创建时,我们改变initialData的值this.initialData = 'Changed Value';}
};

三、Vue3中的watch

3.1、向下兼容(Vue2)的Options API

        在Vue3中,使用Options API时,watch的用法与Vue2相同。

export default {data() {return {watchedProperty: ''};},watch: {watchedProperty(newVal, oldVal) {console.log(`从 ${oldVal} 变为 ${newVal}`);}}
};

3.2、使用Composition API

3.2.1、基础语法

        在Vue3的Composition API中,watch 以函数的形式存在,可以更细粒度地控制侦听器。watch函数接收两个参数:

  1. 被监听的属性:你想要观察的响应式数据源,可以是响应式引用 ref、计算属性 computed,或者返回响应式值的函数。
  2. 回调函数:当被监听的属性发生变化时调用的函数,它接收新值和旧值作为参数。

使用Composition API的watch提供了更大的灵活性,例如,你可以观察更复杂的响应式状态,或者使用watchEffect来自动追踪依赖并执行副作用。

3.2.2、基础用法示例

        在Vue 3的Composition API中,基础用法示例如下:

import { watch, ref } from 'vue';export default {setup() {const watchedProperty = ref('');// 使用 watch 函数观察 watchedProperty 的变化watch(watchedProperty, (newVal, oldVal) => {console.log(`从 ${oldVal} 变为 ${newVal}`);});// 也可以观察其他响应式引用或计算属性// watch(() => someComputedProperty, (newVal, oldVal) => { ... });// 返回响应式状态供模板或其他Composition API使用return {watchedProperty};}
};

3.2.3、Vue3中的对象式写法

        写法核心思想和Vue2差不多,只不过变成了箭头函数,随便给个例子就能看懂:

import { ref, watch } from 'vue';// 创建响应式引用
const state = ref({name: 'John Doe',age: 30
});// 使用 watch 函数,同时设置 deep 和 immediate 选项
watch(() => state.value, // 观察的响应式源(newVal, oldVal) => {console.log(`State changed from ${JSON.stringify(oldVal)} to ${JSON.stringify(newVal)}`);},{deep: true,    // 深度观察,观察对象内部属性的变化immediate: true // 立即执行观察者函数}
);

四、Vue3中的watchEffect

        Vue3提倡使用 watchEffect 自动追踪依赖并执行副作用,而不是直接用watch来进行简单的副作用的侦听。副作用通常是指那些与组件渲染无关的操作,如 API 调用、手动更改 DOM 等。watchEffect 不需要显式指定要观察的响应式状态,它会自动追踪其内部使用的响应式引用和状态。这减少了样板代码,当开发者只是想要观察属性的变化时,不用写那么多重复的代码。

import { ref, watch, watchEffect } from 'vue';export default {setup() {// 创建响应式状态const count = ref(0);// 使用 watchEffect 自动追踪 count 并执行副作用watchEffect(() => {console.log(`count is now ${count.value}`);// 当 count 发生变化时,这里的代码会被自动执行});// 使用 watch 观察 count 的变化watch(count, (newValue, oldValue) => {console.log(`count changed from ${oldValue} to ${newValue}`);// 当 count 发生变化时,这里的回调函数会被调用});// 模拟用户交互,改变 count 的值function increment() {count.value++;}return {count,increment};}
};

        说白了,只要将响应式数据写到watchEffect里面,就能自动侦听变化,并执行一些副作用,这样大大减少了开发时的代码负担。

五、总结

        一篇文章同时搞定Vue2和Vue3的侦听器,是不是很棒?不要忘了Vue3中多了一个可选项watchEffect噢。

        意犹未尽?更多精彩前端好文请关注:各种前端问题的技巧和解决方案

        博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

这篇关于管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1049736

相关文章

使用Redis实现会话管理的示例代码

《使用Redis实现会话管理的示例代码》文章介绍了如何使用Redis实现会话管理,包括会话的创建、读取、更新和删除操作,通过设置会话超时时间并重置,可以确保会话在用户持续活动期间不会过期,此外,展示了... 目录1. 会话管理的基本概念2. 使用Redis实现会话管理2.1 引入依赖2.2 会话管理基本操作

Python容器转换与共有函数举例详解

《Python容器转换与共有函数举例详解》Python容器是Python编程语言中非常基础且重要的概念,它们提供了数据的存储和组织方式,下面:本文主要介绍Python容器转换与共有函数的相关资料,... 目录python容器转换与共有函数详解一、容器类型概览二、容器类型转换1. 基本容器转换2. 高级转换示

MySQL数据目录迁移的完整过程

《MySQL数据目录迁移的完整过程》文章详细介绍了将MySQL数据目录迁移到新硬盘的整个过程,包括新硬盘挂载、创建新的数据目录、迁移数据(推荐使用两遍rsync方案)、修改MySQL配置文件和重启验证... 目录1,新硬盘挂载(如果有的话)2,创建新的 mysql 数据目录3,迁移 MySQL 数据(推荐两

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE