vue3+watch

watch—vue3

是一个惰性,所谓惰性,就是被动的去进行调用,而不是主动的去进行触发,可以通过使用immediate来等进行立即执行调用
如何在初始阶段进行触发呢?
了解到watch中的参数
watch(参数一:监听的数据,参数二:回调函数()=>{编辑代码},参数三:option?用于执行一些配置选项)

参数一:是在setup的语法糖中定义的一个数据,
通过ref进行普通的响应式数据,例如字符串,数字类型等
通过reactive进行复杂数据的响应式数据,例如对象,数组等

通过参数一中的数据进行监听,来判断是否需要触发,

参数二:是来进行一个回到函数,当监听到数据在发生变化 到时候,就会去执行这个回调函数。其中第一个参数是新变化的值,第二个是以前的值,这个是在普通的数据进行变化,当复杂的数据进行变化的时候,可以通过数组的方法进行参数定义,那么在第一个参数是以数组进行展示,并且都是新变化的值,第二个参数是以前的值 ,例如

const a=ref(1)
const b=reactive({a:1111})
watch([a,()=>b.a],([onenew,twonew],[oneold,twoold])=>{
  console.log('新'+onenew,'旧'+oneold)
  console.log('新'+twonew,'旧'+twoold)
},{immediate:true})

参数三:就是我们在上面提到的一些配置的问题

第一个是immediate:是在watch在组件进行创建完成之后立即执行,在以上的代码中使用对象的形式进行使用。
第二个是deep:在默认的情况下,监听一个对象或者是数组进行变化的监听的时候,不会往其内部去监听变化,如果我们想要了解更多的变化,就可以使用deep进行深度监听。
第三个是flush:指的是我们进行回到函数中,应该怎么样去执行。在什么时候去执行。
其中flush的值有:

  • async: 同步下执行代码
  • pre:在数据变化之前执行回调函数
  • post:在数据变化完成之后执行回调函数,但是必须在所以依赖都更新完成之后才可以执行。
const a=ref(1)
const b=reactive({a:1111})
watch([a,()=>b.a],([onenew,twonew],[oneold,twoold])=>{
  console.log('新'+onenew,'旧'+oneold)
  console.log('新'+twonew,'旧'+twoold)
},{flush:'sync'})

进行一个扩展watchEffect:
并不是惰性,非惰性,一旦运行就会立即执行,只能访问到最新的数据,不能访问到旧数据。
watchEffect其实也是一个侦听器,也是一个副作用函数,
但是当我们需要监听一个对象的时候,以及引用数据类型的时候,不需要具体到某一个属性,一旦运行就会立即执行,当卸载的时候就会立即停止。
注意:只是依赖项不需要某一个属性,也不需要参数,但是在进行输出的时候需要具体到某一个属性

//通过触发响应式数据进行触发监听,
const c=reactive({
a: {
  name: 'zhangsan',
  agge: 18
}})
watchEffect(()=>{
  console.log('c中的a的属性值'+c.a.agge)
})
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值