为了账号安全,请及时绑定邮箱和手机立即绑定

【金秋打卡】第 13 天 vue基础入门(下)| 2-10 watch 和 watchEffect 的使用和差异性(1)

标签:
Vue.js

这篇文章可以入选评委评选的最佳手记吗?期待ing…

模块名
描述
课程名称
前端工程师2022版
课程章节
vue基础入门(下)
打卡知识进程
知识进程:13 / 21
✔(8)2-4 toRef以及context参数(1)
✔(9)2-5 toRef以及context参数(2)
✔(10)2-7使用 Composition API 开发TodoList(1)
✔(11)2-8使用 Composition API 开发TodoList(2)
✔(12)2-9 computed方法生成计算属性
✔(13)2-10 watch 和 watchEffect 的使用和差异性(1)
x(14)2-11 watch 和 watchEffect 的使用和差异性(2)
主讲老师
Dell
学习开始时间
2022.11.06 19:42
学习结束时间
2022.11.06 20:42
总计时
60 min
课程收获

我们始终围绕是什么+为什么+怎么用
来输出所学收获
(1)是什么:
Vue 里面提供给我们的一个新的API叫做watch。我们可以写一个watch,‍‍监听name叫响应式引用的变化。‍‍当它变化之后会调用后面的回调函数,这个回调函数会接收两个内容,一个叫做‍‍当前的这个是叫currentValue,还可以接收一个叫做prevValue,也就是之前的值。‍‍
(2)怎么玩:
写法参考demo示例。
学习感受/感想/领悟(心得)
希望自己把Vue这块写完后,整理归档,给正在学习Vue或即将学习Vue的同学做个参考,让他们花比我少的时间学到比我好的学习效果。这是我输出的意义。

‍学习目标:
1)Vue3 里面 composition API 里面的新特性。
我的问题:
1)什么是侦听器?
2)怎么使用侦听器?

我们来学习侦听器这块的内容。‍‍
在之前学习基础语法的时候我们已经知道了 watch 这样的侦听器,‍‍
我们来讲在 composition API 里面我们如何来使用 watch 侦听器,‍‍
代码示例:

代码解读:

我们写一个input框,‍‍我们用了 v杠model,(双向绑定,input框,上下同时变化)等于一个叫做name,‍‍前面我也加一个姓名,或者写Name:好了,后面我们什么都不跟。‍‍

然后在下面我们再写一个div,复制一个出来叫Name is dell lee
我们来一个双向绑定,
然后在上面我们来去写这个内容ref默认给一个dell,‍‍把name导出出去,保存,回到页面上我们刷新,‍‍效果:

比如说加一个lee下面就会跟着变,‍‍这是一个很简单的内容,

这里我不用计算属性了,我用一个watch:

也就是在 Vue 里面提供给我们的一个新的API叫做watch,‍‍
在setup函数里面我们可以直接用 watch,
我们可以怎么写?

我们可以写一个watch,‍‍监听name叫响应式引用的变化。‍‍

在这里面‍‍当它变化之后会调用后面的回调函数,这个回调函数会接收两个内容,一个叫做‍‍当前的这个是叫currentValue,
还可以接收一个叫做prevValue,也就是之前的值。‍‍

我可以 console点log一下,
然后到页面上我们‍‍在控制台里面刷新一下,现在什么也没有:

当我去改变 name 的时候,大家看‍‍:

是不是就会打印出这个current。
比如说我再刷新从头来,我这儿加一个a‍‍:

它当前的值就是della。
然后原始这个值就变成了dell。‍‍

我再加个b,当前值就是dellab,上一次的值就是della,‍‍

这就是watch侦听器的作用【啊哈】

这个 watch 它有两个特性,
第一个它是具备一定的 lazy‍‍特性的,就是比较懒,懒惰性。什么叫惰性?此处按下不表,下文会有讲解。
第二个就是参数可以拿到原始和当前值,‍‍

什么叫做lazy?

当页面第一次‍‍展示的时候,你会发现侦听器它并不会去执行,‍‍只有你在这里输入新的内容的时候,它才会去执行,‍‍
所以它是一个惰性执行的。

首次页面展示的时候它不会执行,只有你‍‍变化了之后它才会执行,这叫惰性的执行。‍‍

为什么要说它?
一会我们说其他知识点的时候要做一个对比。‍‍

我们说除了我们可以对这种 ref 形式的基础类型的数据做这种侦听之外,‍‍
我们还可以对一些比如说reactive这样的数据类型做一个监听,
比如在这里我写一个reactive,‍‍这块我就改一下叫做reactive,后面我跟一个对象,‍‍后面叫做dell:

然后这块你就要用nameObj点name:

当然我们也可以写的更精致一些:

如果你这么去写,你把name导出出去就行了,这块还是用‍‍name。

如果现在它是一个reactive这样的数据类型,‍‍我侦听的是谁?
我侦听的是nameObj点name:

如果你这么去写,‍‍你会发现它是有问题的:

大家看说你如果是个 watch 的话,你监听的资源必须是‍‍一个function,一个ref或者其他的一些内容,‍‍
也就是当前你的这个东西它是不满足现在的要求的,这块我们怎么去做呢?‍‍

如果你侦听的是一个reactive这样的数据的话,‍‍这块你不能直接这么写nameObj点name,
你要写一个箭头函数,然后返回‍‍nameObj点name:

这样去写才可以把它变成函数去监听nameObj点name,这样的话‍‍就不会有问题了,我们保存一下,回到这里来刷新,‍‍没有任何的问题:

一定要记住,当如果你去写这种reactive对应的形式引用的时候,‍‍你要在前面写一个箭头函数这种形式去监听你对应想要监听的内容。

侦听器可以侦听一个内容外,其实它可以侦听两个内容,‍‍
比如现在我们再去定义:

比如说EnglishName 巴拉巴拉,
下面展示的是EnglishName,‍‍我去定义 EnglishName:

这块导出要加上。‍‍

然后我们回到页面上刷新,‍‍我改 dell 的时候,大家看 watch 侦听器是执行的:

当我改 lee 的时候watch 侦听器 就不执行了。

我希望改 lee 的时候 watch 侦听器 也执行,‍‍
你可能会这么去写,你是不是把这块代码再复制一下,然后这块写一个englishName:

保存,‍‍刷新,没问题:

但这样写代码是冗余的,‍‍能不能我把 name 和englishName 侦听器写在一起?完全可以。

在watch里面可以接收一个数组,我们在这写一个数组:

它的意思就是侦听器 侦听是这个数组里的内容的变化,如果你name或者englishName变化,
我都会执行后面的这个函数,‍‍当然后面这个函数里面接收的参数也就同样的会发生变化了,它会怎么变化呢?‍‍

首先你侦听的是 name 和englishName,所以它接收的参数也会是一个数组,逗号,‍‍然后后面也是一个数组,当然这块它是curName,对应的是前面的nameObj点name,然后curEng接收到的就是你englishName,
后面这个数组,之前的叫prevName,然后再加一个preEng,它是这么接收的:

也就是你侦听两个数据的变化,‍‍回调函数里面可以获取到这两个数据当前的值以及它之前的值,
这么写完之后我们去打印一下:

保存,‍‍到页面上刷新,我们看一下效果。‍‍

我先改Name 改a:

大家可以看‍‍当前的 name 是della,之前的name 是 dell,
然后改一下 lee:

当前的‍‍lee englishName是leev,然后之前的englishName是lee,‍‍
这样的话就没有什么问题了,我们能把每一次侦听器侦听的这些数据的‍‍内容都展示,或者说都打印出来都获取回来。‍‍

第三个侦听器的特性,‍‍不仅可以侦听一个内容,还可以侦听多个内容、多个‍‍数据的变化,用一个侦听器承载。
怎么承载?
这块写一个数组,发生变化的时候,对应的这几个数据的‍‍内容也可以通过后面回调函数里面的这些参数的数组来获取到,这就是watch的一个应用。

点击查看更多内容
1人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消