Vue3中watchEffect高級(jí)偵聽(tīng)器的具體使用
示例均采用 <script setup>,且包含 typescript 的基礎(chǔ)用法
前言
Vue3 中新增了一種特殊的監(jiān)聽(tīng)器 watchEffect,它的類型是:
function watchEffect( effect: (onCleanup: OnCleanup) => void, options?: WatchEffectOptions ): StopHandle
下面通過(guò)實(shí)例來(lái)理解下它的用法
一、簡(jiǎn)單使用
- 第一個(gè)參數(shù)就是要運(yùn)行的
副作用函數(shù) effect - 函數(shù)內(nèi)
用到哪些數(shù)據(jù)才會(huì)監(jiān)聽(tīng)哪些數(shù)據(jù) - 且會(huì)
立刻執(zhí)行一次(immediate)
<input type="text" v-model="message1" /> <br /> <input type="text" v-model="message2" /> <br />
import { ref, watchEffect } from "vue";
const message1 = ref<string>("飛機(jī)");
const message2 = ref<string>("火車");
watchEffect(() => {
console.log("message1========>,", message1);
// 不使用 message2 就不會(huì)監(jiān)聽(tīng) message2
// console.log("message2========>,", message2);
});
二、副作用 effect 的參數(shù)
- effect 的參數(shù) 也是一個(gè)
函數(shù),用來(lái)注冊(cè)清理回調(diào)。 清理回調(diào)會(huì)在該副作用下一次執(zhí)行前被調(diào)用,可以用來(lái)清理無(wú)效的副作用,例如等待中的異步請(qǐng)求
<input type="text" v-model="message1" /> <br /> <input type="text" v-model="message2" /> <br />
import { ref, watchEffect } from "vue";
const message1 = ref<string>("飛機(jī)");
const message2 = ref<string>("火車");
watchEffect((onCleanup) => {
console.log("message11111========>,", message1);
console.log("message22222========>,", message2);
onCleanup(() => {
console.log("onCleanup —————— 下一次運(yùn)行之前要做的事");
});
});
頁(yè)面刷新,首次打印:

更改輸入框的值,再次打?。?/h3>

三、watchEffect 返回值
- 返回值是一個(gè)用來(lái)
停止偵聽(tīng)器的函數(shù),調(diào)用后不再偵聽(tīng) - 需要注意的是:停止時(shí),
不影響最后一次 onCleanup 的執(zhí)行
<input type="text" v-model="message1" /> <br /> <input type="text" v-model="message2" /> <br /> <button @click="stopWatch">停止watchEffect</button>
const stop = watchEffect((onCleanup) => {
console.log("message11111========>,", message1);
console.log("message22222========>,", message2);
onCleanup(() => {
console.log("onCleanup —————— 下一次運(yùn)行之前要做的事");
});
});
const stopWatch = () => {
stop();
};
頁(yè)面刷新,首次打?。?/h3>

更改輸入框的值,再次打?。?/h3>

點(diǎn)擊按鈕 停止偵聽(tīng),再次打?。?/h3>

四、options配置
watchEffect 的第二個(gè)參數(shù)是配置項(xiàng):
flush:watch 的執(zhí)行順序pre|post|sync,默認(rèn):pre,具體含義可以看上一篇 watch 中的解釋- 一般需要在 dom 更新之后再獲取的情況,可以設(shè)置為
post
onTrack用于開發(fā)環(huán)境調(diào)試onTrigger用于開發(fā)環(huán)境調(diào)試
<input id="ipt" v-model="iptVal" />
const iptVal = ref<string>("aa");
watchEffect(
() => {
// 測(cè)試 flush
const spanEle = document.getElementById("ipt");
// flush = pre 時(shí),打印 null; flush = post 時(shí),打印節(jié)點(diǎn)
console.log("spanEle========>,", spanEle);
// 修改 iptVal 測(cè)試 onTrack、onTrigger
console.log("iptVal============>", iptVal.value);
},
{
flush: "post",
// 收集依賴時(shí)觸發(fā)
onTrack: () => {
debugger;
},
// 更新時(shí)觸發(fā)
onTrigger: () => {
debugger;
},
}
);
五、周邊 api
watchPostEffect():watchEffect()使用flush: 'post'選項(xiàng)時(shí)的別名watchSyncEffect():watchEffect()使用flush: 'sync'選項(xiàng)時(shí)的別名
到此這篇關(guān)于Vue3中watchEffect高級(jí)偵聽(tīng)器的具體使用的文章就介紹到這了,更多相關(guān)Vue3 watchEffect高級(jí)偵聽(tīng)器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Vue3中Watch、Watcheffect、Computed的使用和區(qū)別解析
- vue3 watch和watchEffect的使用以及有哪些區(qū)別
- Vue3.0監(jiān)聽(tīng)器watch與watchEffect詳解
- vue3中的watch和watchEffect實(shí)例詳解
- 淺談Vue3中watchEffect的具體用法
- Vue3?中?watch?與?watchEffect?區(qū)別及用法小結(jié)
- VUE3中watch和watchEffect的用法詳解
- 一文搞懂Vue3中watchEffect偵聽(tīng)器的使用
- Vue3中watchEffect和watch的基礎(chǔ)應(yīng)用詳解
- Vue3中watch與watchEffect使用方法詳解
相關(guān)文章
vue3中setup語(yǔ)法糖下通用的分頁(yè)插件實(shí)例詳解
這篇文章主要介紹了vue3中setup語(yǔ)法糖下通用的分頁(yè)插件,實(shí)例代碼介紹了自定義分頁(yè)插件:PagePlugin.vue,文中提到了vue3中setup語(yǔ)法糖下父子組件之間的通信,需要的朋友可以參考下2022-10-10
在vue項(xiàng)目中如何獲取視頻的時(shí)長(zhǎng)
這篇文章主要介紹了在vue項(xiàng)目中如何獲取視頻的時(shí)長(zhǎng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
vue打包的時(shí)候自動(dòng)將px轉(zhuǎn)成rem的操作方法
這篇文章主要介紹了vue打包的時(shí)候自動(dòng)將px轉(zhuǎn)成rem的操作方法,需要的朋友可以參考下2018-06-06
vue-element-admin?登陸及目錄權(quán)限控制的實(shí)現(xiàn)
本文主要介紹了vue-element-admin?登陸及目錄權(quán)限控制的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
利用Vue實(shí)現(xiàn)簡(jiǎn)易播放器的完整代碼
這篇文章主要給大家介紹了關(guān)于如何利用Vue實(shí)現(xiàn)簡(jiǎn)易播放器的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12

