0

0

vue3下的watch怎么使用

WBOY

WBOY

发布时间:2023-05-17 12:14:26

|

3690人浏览过

|

来源于亿速云

转载

    既然是数据监听,监听的是它的变化。那么就需要能够捕获它的变更,于是监听的数据必然要是响应式数据

    watch(WatcherSource, Callback, [WatchOptions])参数:WatcherSource:想要监听的响应式数据。Callback:执行的回调函数,入参(newValue,oldValue)。[WatchOptions]:deep、immediate、flush可选。

    对于WatchOptions的参数配置:

    deep:当需要对对象等引用类型数据进行深度监听时,设置deep: true,默认值是false。
    immediate:默认情况下watch是惰性的,设置immediate: true时,watch会在初始化时立即执行回调函数一次。
    flush:控制回调函数的执行时机,。它可设置为 pre、post 或 sync。
        pre:默认值,当监听的值发生变更时,优先执行回调函数(在dom更新之前执行)。
        post:dom更新渲染完毕后,执行回调函数。
        sync:一旦监听的值发生了变化,同步执行回调函数(建议少用)。

    一,监听单个数据ref

    const count = ref(1);
    watch(count, (newValue, oldValue) => {
      console.log('值发生了变更', newValue, oldValue);
    });

    可以获取到新值和旧值。

    二,监听引用类型数据ref:深度监听

    const count = ref({
      a: 1,
      b: 2
    });
    const handleClick = function () {
     count.value.a = 5;
    };
    watch(count, (newValue, oldValue) => {
      console.log('值发生了变更', newValue, oldValue);
    });

    即使整个数组作为引用数据类型被监听,它内部的某一项发生变更也不会被观察到。所以watch中的代码并没有执行。

    立即学习前端免费学习笔记(深入)”;

    1,引用类型ref直接深度监听

    此时,就需要使用深度监听:deep:true

    const count = ref({
      a: 1,
      b: 2
    });
    const handleClick = function () {
      count.value.a = 5;
    };
    watch(
      count,
      (newValue, oldValue) => {
        console.log('值发生了变更', newValue, oldValue);
      },
      { deep: true }
    );

    值发生了变更 Proxy {a: 5, b: 2} Proxy {a: 5, b: 2}

    可以注意到的是,深度监听的需要是这个引用数据类型自身,而不是其中的属性。并且,他只能获取到新值,而获取不到旧的值。

    2,引用类型ref深拷贝深度监听

    const count = ref({
      a: 1,
      b: 2
    });
    const handleClick = function () {
      count.value.a = 5;
    };
    watch(
      () => {
        return { ...count.value };
      },
      (newValue, oldValue) => {
        console.log('值发生了变更', newValue, oldValue);
      },
      { deep: true }
    );

    这样把watch的引用类型数据源深拷贝一份,即可完成对新旧值得获取:

    值发生了变更 {a: 5, b: 2} {a: 1, b: 2}

    三,监听单个数据:reactive

    const single = reactive({ count: 1, test: 2 });
    const handleClick = function () {
      single.count++;
    };
    watch(
      () => single.count,
      (newValue, oldValue) => {
        console.log('值发生了变更', newValue, oldValue);
      },
      { immediate: true }
    );

    这里主要是() => single.count,监听的是single中的count,只有这个属性发生了变化才会触发回调函数。这种情况下是可以获取到新旧值的。

    四,监听引用类型数据:reactive

    
    
    

    reactive的数据,用不用deep:true是没有影响的,single中的一个属性发生了变化,都能被监听到,继而执行回调函数。

    和三中有所不同的是,这种情况下是只能获取到新值的。

    给表格加链接
    给表格加链接

    给表格加链接,一般我们是不怎么使用表格的,但是有些时候我们会有这块的需求,企业网站或商城网站都可以使用,给表格加上链接,需要通过js来控制,php中文网推荐下载!

    下载

    五,immediate: true

    默认情况下watch是惰性的,当我们设置immediate: true时,watch会在初始化时立即执行回调函数

    const count = ref(1);
    const handleClick = function () {
      count.value++;
    };
    watch(
      count,
      (newValue, oldValue) => {
        console.log('值发生了变更', newValue, oldValue);
      },
      { deep: true, immediate: true }
    );

    六,监听多个数据源

    const count = ref(1);
    const double = ref(2);
    const handleClick = function () {
      count.value++;
      double.value++;
    };
    watch(
      [count, double],
      (newValue, oldValue) => {
        console.log('值发生了变更', newValue, oldValue);
      },
      { deep: true, immediate: true }
    );

    如果两个值同时发生变更,则会仅触发一次watch的回调函数,而对于每个值的变更都会引发watch的回调函数。

    如果想变更一格数据就触发一次回调,可以在两个数据变更中间加下nextTick。

    七,flush的配置

    1,默认情况下在dom渲染完毕前调用回调函数

    回调函数优先于DOM更新执行,监听值变更时,flush默认为pre。这就意味着,如果在回调函数中有相关dom的操作,而参数里面配置了immediate:true,则会报错,因为这个时候dom还没有被渲染,是获取不到dom的。

    接下来看下代码:

    
    
    

    得到的结果:

    --- 1值发生了变更 2 1

    在回调函数中,新的值已经变成了2,但获取到的DOM仍然是之前的。默认情况下,flush的值为pre。当值发生变化时,回调函数将在DOM更新之前被触发执行。

    2,flush: 'post’在dom渲染完毕后执行回调函数

    
    
    

    得到的结果:

    --- 2值发生了变更 2 1

    当回调函数被调用时,DOM已经更新完成,此时获取到的DOM是经过数据更改后更新完成的DOM。

    相关专题

    更多
    数据类型有哪几种
    数据类型有哪几种

    数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    295

    2023.10.31

    php数据类型
    php数据类型

    本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

    216

    2025.10.31

    counta和count的区别
    counta和count的区别

    Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    192

    2023.11.20

    DOM是什么意思
    DOM是什么意思

    dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

    2687

    2024.08.14

    excel制作动态图表教程
    excel制作动态图表教程

    本专题整合了excel制作动态图表相关教程,阅读专题下面的文章了解更多详细教程。

    24

    2025.12.29

    freeok看剧入口合集
    freeok看剧入口合集

    本专题整合了freeok看剧入口网址,阅读下面的文章了解更多网址。

    74

    2025.12.29

    俄罗斯搜索引擎Yandex最新官方入口网址
    俄罗斯搜索引擎Yandex最新官方入口网址

    Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    207

    2025.12.29

    python中def的用法大全
    python中def的用法大全

    def关键字用于在Python中定义函数。其基本语法包括函数名、参数列表、文档字符串和返回值。使用def可以定义无参数、单参数、多参数、默认参数和可变参数的函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    16

    2025.12.29

    python改成中文版教程大全
    python改成中文版教程大全

    Python界面可通过以下方法改为中文版:修改系统语言环境:更改系统语言为“中文(简体)”。使用 IDE 修改:在 PyCharm 等 IDE 中更改语言设置为“中文”。使用 IDLE 修改:在 IDLE 中修改语言为“Chinese”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

    18

    2025.12.29

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Vue3.x 工具篇--十天技能课堂
    Vue3.x 工具篇--十天技能课堂

    共26课时 | 1.4万人学习

    Vue3.x 核心篇--十天技能课堂
    Vue3.x 核心篇--十天技能课堂

    共30课时 | 1.4万人学习

    Vue3.x新特性篇--十天基础课堂
    Vue3.x新特性篇--十天基础课堂

    共20课时 | 1.1万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号