学习vue3 第八章 (watchEffect高级侦听器)

本文介绍了Vue中的watchEffect函数,用于实时监听ref变量并执行回调。内容涵盖如何监听依赖、清除副作用、停止跟踪以及控制副作用的刷新时机,如flush选项的使用。
摘要由CSDN通过智能技术生成

watchEffect

立即执行传入的一个函数,同时响应式追踪其依赖,并在其依赖变更时重新运行该函数。

//用到几个监听几个 而且是非惰性 会默认调用一次

import {ref, watchEffect} from "vue"

let msg1 = ref("")
let msg2 = ref("")

watchEffect(() => {
    console.log(msg1.value) //监听msg1
    console.log(msg2.value) //监听msg2
})

清除副作用

就是在触发监听之前会调用一个函数可以处理你的逻辑例如防抖

import {ref, watchEffect} from "vue"

let msg1 = ref("")
let msg2 = ref("")

watchEffect((oninvalidate) => {
    console.log(msg1.value) //监听msg1
    console.log(msg2.value) //监听msg2
    
    oninvalidate(() => {
        //先调用此函数
    })
})

停止跟踪

停止跟踪 watchEffect 返回一个函数 调用之后将停止更新

import {ref, watchEffect} from "vue"

let msg1 = ref("")
let msg2 = ref("")

const stop = watchEffect((oninvalidate) => {
    console.log(msg1.value) //监听msg1
    console.log(msg2.value) //监听msg2
    
    oninvalidate(() => {
        //先调用此函数
    })
}, {
    flush: "stop",
    onTrigger() {
        //调试watchEffect
    }

})

stop()

其他配置项

副作用刷新时机 flush 一般使用post

pre: 组件更新前执行

post:组件更新后执行

sync:强制效果始终同步触发

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值