gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

一文了解Vue3中的watchEffect,聊聊其應(yīng)用場景!

本篇文章帶大家了解一下Vue3中的watchEffect,介紹一下它的副作用,并聊聊它可以做什么事情,希望對大家有所幫助!

一文了解Vue3中的watchEffect,聊聊其應(yīng)用場景!

watchEffect,它立即執(zhí)行傳入的一個函數(shù),同時響應(yīng)式追蹤其依賴,并在其依賴變更時重新運(yùn)行該函數(shù)。(學(xué)習(xí)視頻分享:vue視頻教程)

換句話說:watchEffect相當(dāng)于將watch 的依賴源和回調(diào)函數(shù)合并,當(dāng)任何你有用到的響應(yīng)式依賴更新時,該回調(diào)函數(shù)便會重新執(zhí)行。不同于 watchwatchEffect 的回調(diào)函數(shù)會被立即執(zhí)行(即 { immediate: true }

此文主要講述怎樣利用清除副作用使我們的代碼更加優(yōu)雅~

watchEffect的副作用

什么是副作用(side effect),簡單的說副作用就是執(zhí)行某種操作,如對外部可變數(shù)據(jù)或變量的修改,外部接口的調(diào)用等。watchEffect的回調(diào)函數(shù)就是一個副作用函數(shù),因?yàn)槲覀兪褂?code>watchEffect就是偵聽到依賴的變化后執(zhí)行某些操作。

當(dāng)執(zhí)行副作用函數(shù)時,它勢必會對系統(tǒng)帶來一些影響,如在副作用函數(shù)里執(zhí)行了一個定時器setInterval,因此我們必須處理副作用。Vue3watchEffect偵聽副作用傳入的函數(shù)可以接收一個 onInvalidate 函數(shù)作為入?yún)ⅲ脕碜郧謇硎r的回調(diào)。當(dāng)以下情況發(fā)生時,這個失效回調(diào)會被觸發(fā):

  • 副作用即將重新執(zhí)行時(即依賴的值改變)
  • 偵聽器被停止 (通過顯示調(diào)用返回值停止偵聽,或組件被卸載時隱式調(diào)用了停止偵聽)
import { watchEffect, ref } from 'vue'  const count = ref(0) watchEffect((onInvalidate) => {   console.log(count.value)   onInvalidate(() => {     console.log('執(zhí)行了onInvalidate')   }) })  setTimeout(()=> {   count.value++ }, 1000)

上述代碼打印的順序?yàn)椋?0 -> 執(zhí)行了onInvalidate,最后執(zhí)行 -> 1

分析:初始化時先打印count的值0, 然后由于定時器把count的值更新為1, 此時副作用即將重新執(zhí)行,因此onInvalidate的回調(diào)函數(shù)會被觸發(fā),打印執(zhí)行了onInvalidate,然后執(zhí)行了副作用函數(shù),打印count的值1

import { watchEffect, ref } from 'vue'  const count = ref(0) const stop = watchEffect((onInvalidate) => {   console.log(count.value)   onInvalidate(() => {     console.log('執(zhí)行了onInvalidate')   }) })  setTimeout(()=> {   stop() }, 1000)

上述代碼:當(dāng)我們顯示執(zhí)行stop函數(shù)停止偵聽,此時也會觸發(fā)onInvalidate的回調(diào)函數(shù)。同樣,watchEffect所在的組件被卸載時會隱式調(diào)用stop函數(shù)停止偵聽,故也能觸發(fā)onInvalidate的回調(diào)函數(shù)。

watchEffect的應(yīng)用

利用watchEffect的非惰性執(zhí)行,以及傳入的onInvalidate 函數(shù),我們可以做什么事情了?

場景一:平時我們定義一個定時器,或者監(jiān)聽某個事件,我們需要在mounted生命周期鉤子函數(shù)內(nèi)定義或者注冊,然后組件銷毀之前在beforeUnmount鉤子函數(shù)里清除定時器或取消監(jiān)聽。這樣做我們的邏輯被分散在兩個生命周期,不利于維護(hù)和閱讀。

如果我利用watchEffect,創(chuàng)造和銷毀邏輯放在了一起,此時代碼更加優(yōu)雅易讀~

// 定時器注冊和銷毀 watchEffect((onInvalidate) => {   const timer = setInterval(()=> {     // ...   }, 1000)   onInvalidate(() => clearInterval(timer)) })  const handleClick = () => {  // ... } // dom的監(jiān)聽和取消監(jiān)聽 onMounted(()=>{   watchEffect((onInvalidate) => {     document.querySelector('.btn').addEventListener('click', handleClick, false)     onInvalidate(() => document.querySelector('.btn').removeEventListener('click', handleClick))   }) })

場景二:利用watchEffect作一個防抖節(jié)流(如取消請求)

const id = ref(13) watchEffect(onInvalidate => {    // 異步請求   const token = performAsyncOperation(id.value)   // 如果id頻繁改變,會觸發(fā)失效函數(shù),取消之前的接口請求   onInvalidate(() => {     // id has changed or watcher is stopped.     // invalidate previously pending async operation     token.cancel()   }) })

……

當(dāng)然watchEffect還能做很多事情,比如打開一個修改的modal彈窗,如果檢測到id變化,我們可以在onInvalidate函數(shù)內(nèi),重置初始參數(shù)…這里只是一個拋磚引玉的作用,望大家多多發(fā)掘~

(學(xué)習(xí)視頻分享:web前端開發(fā)、編程基礎(chǔ)視頻)

贊(0)
分享到: 更多 (0)
?
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
国产日韩第一页| 午夜影院免费版| www黄色在线| 欧美婷婷精品激情| 五月花丁香婷婷| 伊人久久在线观看| a级黄色一级片| 92看片淫黄大片一级| 成人亚洲精品777777大片| 亚洲午夜激情影院| 欧美 亚洲 视频| 青青青在线播放| 在线免费黄色网| 91国在线高清视频| 熟女人妇 成熟妇女系列视频| 亚洲成人天堂网| 日韩成人手机在线| 999在线免费视频| 欧美另类videos| 乱子伦视频在线看| www.久久com| 欧美激情成人网| 日韩视频在线免费播放| 日本wwww视频| 天天操夜夜操很很操| 欧美 日韩 国产 高清| 在线观看国产一级片| 18黄暴禁片在线观看| www.亚洲高清| 毛片在线播放视频| 日本高清一区二区视频| 青青草视频在线免费播放| 欧美日韩在线观看不卡| 黄色一级在线视频| www亚洲国产| 日本a√在线观看| 大陆av在线播放| 亚洲一区二区图片| 日本va中文字幕| 亚洲理论电影在线观看| 色婷婷一区二区三区在线观看| 免费无码不卡视频在线观看| www.日本久久| 亚洲天堂网一区| 自慰无码一区二区三区| 2021国产视频| 亚洲成人天堂网| 人妻有码中文字幕| 九九爱精品视频| 欧美大片免费播放| 欧洲美女亚洲激情| 97人人爽人人| 最新国产黄色网址| 亚洲第一中文av| 国产视频在线视频| 国产成人a亚洲精v品无码| 日韩精品在线中文字幕| 女人被男人躁得好爽免费视频| 国产成人美女视频| 天堂av在线8| 青青草久久伊人| 亚洲精品手机在线观看| 天天爽人人爽夜夜爽| 亚洲综合日韩欧美| 国产亚洲视频一区| 一区二区三区四区毛片| 91视频这里只有精品| 潘金莲激情呻吟欲求不满视频| www.这里只有精品| 亚洲一区精品视频在线观看| 久久婷婷中文字幕| 国产卡一卡二在线| 91精品国产毛片武则天| 日韩中文在线字幕| 无码 制服 丝袜 国产 另类| www.在线观看av| 精品国产一二三四区| 国产淫片免费看| 欧美国产日韩在线播放| 一级黄色录像在线观看| 亚洲第一精品区| 欧美日韩激情四射| 99福利在线观看| 黄色一级二级三级| 日韩不卡的av| 精品人妻人人做人人爽| 成人综合视频在线| 九九热在线免费| 美女黄色片网站| 免费看黄在线看| 少妇性l交大片| 日本一本在线视频| 鲁一鲁一鲁一鲁一澡| 岛国毛片在线播放| 欧美性受黑人性爽| av之家在线观看| 日本在线一二三区| 国产91沈先生在线播放| 国产日韩成人内射视频 | 日本中文字幕二区| 麻豆md0077饥渴少妇| 欧美精品自拍视频| 自拍偷拍一区二区三区四区| www婷婷av久久久影片| 国产熟女高潮视频| 欧美 国产 精品| 男人舔女人下面高潮视频| 四虎免费在线观看视频| 欧洲av无码放荡人妇网站| 国产精品自在自线| 国产欧美日韩网站| 北条麻妃亚洲一区| 国产成人久久婷婷精品流白浆| 亚洲一区二区偷拍| 精品99在线视频| 日本不卡一区二区三区四区| 亚洲欧洲日产国码无码久久99| 午夜久久福利视频| 欧美色图色综合| 亚洲成人手机在线观看| 999精品网站| 欧美国产日韩激情| 日本一级淫片演员| 日本男人操女人| 亚洲精品无码国产| 亚洲小说欧美另类激情| 男女无套免费视频网站动漫| 欧美成人精品免费| 欧美大片免费播放| 九九九九九九九九| 91香蕉视频导航| 国产成人av影视| 精品国产一二三四区| 日韩一级特黄毛片| 久久久久亚洲av无码专区喷水| 中文字幕第80页| 国产亚洲综合视频| 国产一级爱c视频| 人人妻人人澡人人爽欧美一区双| 国产九九九视频| 红桃视频 国产| 在线播放av中文字幕| 日本激情综合网| 手机在线看福利| 国产自偷自偷免费一区 | 色乱码一区二区三区在线| 国产精品亚洲二区在线观看| 99热在线这里只有精品| 成品人视频ww入口| 精品国产一区二区三区无码| 91大学生片黄在线观看| 最新av网址在线观看| 黄色免费高清视频| 老司机av福利| 天堂在线一区二区三区| 色偷偷中文字幕| 成年人三级视频| 欧美久久久久久久久久久久久久| 成人一区二区av| 久久99久久99精品| av在线播放亚洲| 成人黄色片视频| 999精品视频在线| 爱豆国产剧免费观看大全剧苏畅| 国产三级三级看三级| mm131国产精品| 精品一区二区成人免费视频 | 日韩在线综合网| 一级特黄性色生活片| 久久撸在线视频| 男女爱爱视频网站| 国产精彩视频一区二区| 人妻熟女一二三区夜夜爱| 亚洲 激情 在线| 福利网在线观看| 色欲色香天天天综合网www| 人妻精品无码一区二区三区| 狠狠热免费视频| 中文字幕av久久| 乱妇乱女熟妇熟女网站| 午夜久久久精品| 在线观看17c| 国产日韩一区二区在线| 免费精品99久久国产综合精品应用| 伊人免费视频二| 日本一道本久久| 亚洲成色www.777999| 国产免费xxx| 哪个网站能看毛片| 在线免费黄色小视频| av免费看网址| 色免费在线视频| 日本精品久久久久久久久久| 成年人在线看片| 米仓穗香在线观看| caopor在线视频| 2022中文字幕| 玖玖爱视频在线| 青青青免费在线| 欧美一级免费在线|