管理数据必备;侦听器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噢。

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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/697255.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Qt实现简易播放器

效果如图 源码地址: 简易播放器: 基于Qt的简易播放器,底层采用VLC源码 - Gitee.com GitHub:GitHub - a-mo-xi-wei/easy-player: 基于Qt的调用VLC的API的简易播放器

Running Gradle task ‘assembleDebug‘ Flutter项目

基于Android方面运行Flutter项目一直卡在 Launching lib\main.dart on Android SDK built for x86 in debug mode… Running Gradle task ‘assembleDebug’… 基础原因: 默认存放Gradle插件包的Maven仓库是国外(需VPN) 我的原因: 缺少JDK和缺少Androi…

tcp协议中机制的总结

目录 总结 分析 三次握手 总结 分析 其中,序列号不止用来排序,还可以用在重传时去重 确认应答是机制中的核心 因为都需要依靠应答来拿到协议字段,从而判断是否触发机制 保证可靠性的策略也可以提高效率,比如: 流量控制,可以根据多个因素来动态调整数据发送量拥塞控制也是,让…

支持YUV和RGB格式两路视频同时播放

1.头文件&#xff1a; sdlqtrgb.h #pragma once #include <QtWidgets/QWidget> #include "ui_sdlqtrgb.h" #include <thread> class SdlQtRGB : public QWidget {Q_OBJECTpublic:SdlQtRGB(QWidget* parent Q_NULLPTR);~SdlQtRGB(){is_exit_ true;//等…

现实转虚拟:Video2Game引领3D互动体验

在当今数字化时代&#xff0c;虚拟环境的创建对于游戏开发、虚拟现实应用和自动驾驶模拟器等多个领域至关重要。然而&#xff0c;传统的虚拟环境创建过程不仅复杂而且成本高昂&#xff0c;通常需要专业人员和专业软件开发工具的参与。例如&#xff0c;著名的《侠盗猎车手V》以其…

「51媒体」江苏媒体宣传报道,邀请媒体报道资源汇总

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 江苏作为中国东部的重要省份&#xff0c;拥有丰富的媒体资源&#xff0c;包括电视台、广播电台、报纸以及网络媒体。 电视台 江苏卫视&#xff1a;作为江苏省唯一的省级卫视台&#xff…

Nvidia/算能 +FPGA+AI大算力边缘计算盒子:桥梁结构安全监测

中国铁路设计集团有限公司&#xff08;简称中国铁设&#xff09;&#xff0c;原铁道第三勘察设计院集团有限公司&#xff08;铁三院&#xff09;&#xff0c;是中国国家铁路集团有限公司所属的唯一设计企业&#xff0c;成立于1953年&#xff0c;总部位于天津市&#xff0c;是以…

基于机器学习的锂电池RUL SOH预测

数据集为NASA锂电池数据集。 import datetimeimport numpy as npimport pandas as pdfrom scipy.io import loadmatfrom sklearn.preprocessing import MinMaxScalerfrom sklearn.metrics import mean_squared_errorfrom sklearn import metricsimport matplotlib.pyplot as p…

python tushare股票量化数据处理:笔记

1、安装python和tushare及相关库 matplotlib pyplot pandas pandas_datareader >>> import matplotlib.pyplot as plt >>> import pandas as pd >>> import datetime as dt >>> import pandas_datareader.data as web 失败的尝试yf…

01——生产监控平台——WPF

生产监控平台—— 一、介绍 VS2022 .net core(net6版本&#xff09; 1、文件夹&#xff1a;MVVM /静态资源&#xff08;图片、字体等&#xff09; 、用户空间、资源字典等。 2、图片资源库&#xff1a; https://www.iconfont.cn/ ; 1.资源字典Dictionary 1、…

攻防演练之-动员大会

清晨的阳光透过薄雾洒在甲方的攻防演练中心。由于国家对于重点行业的数据灾备的要求。因此每一家企业都会选择在不同的地理位置建多个数据中心&#xff0c;包括一个生产中心、一个同城灾难备份中心、一个异地灾难备份中心。通过这种方式将业务分布在不同地理位置的数据中心&…

PowerDesigner 16.5安装教程

&#x1f4d6;PowerDesigner 16.5安装教程 ✅1. 下载✅2. 安装 ✅1. 下载 官网地址&#xff1a;https://www.powerdesigner.biz/EN/powerdesigner/powerdesigner-licensing-history.php 云盘下载&#xff1a;https://www.123pan.com/s/4brbVv-aUoWA.html ✅2. 安装 1.运行P…

Linux网络诊断工具mtr命令详解

目录 一、mtr概述 二、mtr的特点 1、动态路由显示 2、数据包类型 3、显示延迟和丢包 4、过滤和日志 5、网络探测 三、基本用法 1、基本语法 2、帮助 3、常用选项 四、输出解释 1、常见mtr命令及其输出 2、输出解释 四、命令实例 1. 最基本的用法 2. 显示报告形式…

Leetcode3170. 删除星号以后字典序最小的字符串

Every day a Leetcode 题目来源&#xff1a;3170. 删除星号以后字典序最小的字符串 解法1&#xff1a;栈 由于要去掉最小的字母&#xff0c;为了让字典序尽量小&#xff0c;相比去掉前面的字母&#xff0c;去掉后面的字母更好。 从左到右遍历字符串 s&#xff0c;用 26 个栈…

Collections工具类及其案例

package exercise;public class Demo1 {public static void main(String[] args) {//可变参数//方法形参的个数是可以发生变化的//格式&#xff1a;属性类型...名字//int...argsint sum getSum(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);System.out.println(sum);}//底层&#xff1a;可…

嵌入式仪器模块:DMM LCR SMU 及自动化测试软件

• 6 位数字表显示 • 24 位分辨率 • 250 KSPS 采样率 • 电源和数字 I/O 均采用隔离抗噪技术 应用场景 • 电压、电流、电阻、电感、电容的高精度测量 • 二极管/三极管测试 通道1222输入阻抗电压10 MΩHigh-Z, 10 MΩHigh-Z电流10 Ω50 mΩ / 2 Ω / 2 KΩ2 KΩ / 2 M…

Upscayl:款利用人工智能技术,深度学习算法,实现图像无损放大和增强的强大工具。

Upscayl AI&#xff1a; Upscayl AI是一款基于先进的人工智能技术&#xff0c;特别是深度学习算法开发的图像增强工具。它能够智能地分析并改善图像质量&#xff0c;实现无损放大、细节重建和模糊消除&#xff0c;让老旧、低分辨率或模糊的照片焕发新生&#xff0c;达到高清画…

23.在游戏中按下Home键呼出辅助窗口

上一个内容&#xff1a;22.钩子注入原理 在 22.钩子注入原理 它的代码上进行修改 效果图&#xff1a; 首先在CWndMain.h文件中添加下图红框里的东西 ChangeShowState函数的实现 void CWndMain::ChangeShowState() {UiShow !UiShow;ShowWindow(UiShow); } OnInitDialog函数…

在 Android App 里使用 C 代码 - NDK

原生开发套件 (NDK) 是一套工具&#xff0c;使能够在 Android 应用中使用 C 和 C 代码&#xff0c;并提供众多平台库&#xff0c;可使用这些平台库管理原生 activity 和访问实体设备组件&#xff0c;例如传感器和触控输入。 NDK 可能不适合大多数 Android 编程初学者&#xff…

保存图片奇怪的bug

今天发现一个奇怪的bug 这个的dpi是100de ,但是我取完切片之后&#xff0c;发现这个结果就变了