日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

精準解析 useLayoutEffect 與 useEffect 的執(zhí)行時機

來源: 責編: 時間:2024-01-17 10:13:53 275觀看
導(dǎo)讀我們前面花了大量篇幅,從基礎(chǔ)、理論、實踐、總結(jié)幾個方面,全方位的為大家分析了 useEffect。除此之外,React 還提供了一個與 useEffect 幾乎一樣的 hook,它就是useLayoutEffect。我們約定,useEffect 傳入的第一個參數(shù)為 ef

Vms28資訊網(wǎng)——每日最新資訊28at.com

我們前面花了大量篇幅,從基礎(chǔ)、理論、實踐、總結(jié)幾個方面,全方位的為大家分析了 useEffect。除此之外,React 還提供了一個與 useEffect 幾乎一樣的 hook,它就是useLayoutEffect。Vms28資訊網(wǎng)——每日最新資訊28at.com

我們約定,useEffect 傳入的第一個參數(shù)為 effect,useLayoutEffect 傳入的第一個參數(shù)為 layoutEffect。Vms28資訊網(wǎng)——每日最新資訊28at.com

他們的語法為:Vms28資訊網(wǎng)——每日最新資訊28at.com

// 中括號表示參數(shù)可選useEffect(effect[, deps])
useLayoutEffect(layoutEffect[, deps])

兩個 hook 有高度相似的語義。Vms28資訊網(wǎng)——每日最新資訊28at.com

第一個參數(shù) layoutEffect 為一個函數(shù),定義為副作用執(zhí)行邏輯,我們也可以在 layoutEffect 中定義返回函數(shù)。當依賴項發(fā)生了變化時,返回函數(shù)會使用依賴項舊值首先執(zhí)行,然后再執(zhí)行 layoutEffect。Vms28資訊網(wǎng)——每日最新資訊28at.com

useLayoutEffect(() => {  // ...    return () => {}}, [state])

第二個參數(shù)為依賴項數(shù)組。React 內(nèi)部會使用 Object.is 去比較依賴項是否發(fā)生了變化,我們通常會選擇使用 state 或者 props 等響應(yīng)性數(shù)據(jù)作為依賴項。依賴項也可以不傳,此時 layoutEffect 在每次狀態(tài)發(fā)生變化時都會執(zhí)行。Vms28資訊網(wǎng)——每日最新資訊28at.com

useLayoutEffect 與 useEffect 唯一的區(qū)別在于 effect 與 layoutEffect 執(zhí)行時機的不同。Vms28資訊網(wǎng)——每日最新資訊28at.com

我們借助一個例子來仔細分析他們的準確執(zhí)行時機。Vms28資訊網(wǎng)——每日最新資訊28at.com

首先是 useEffect。Vms28資訊網(wǎng)——每日最新資訊28at.com

const [count, setCount] = useState(0)useEffect(() => {  document.title = `React ${count}`})

effect 會在組件渲染完成之后執(zhí)行。這里組件渲染完成的意思是當組件內(nèi)容已經(jīng)呈現(xiàn)在頁面上之后,effect 再執(zhí)行,具體的步驟如下圖所示:Vms28資訊網(wǎng)——每日最新資訊28at.com

Vms28資訊網(wǎng)——每日最新資訊28at.com

在事件循環(huán)中, effect 是被定義為宏任務(wù),在下一輪循環(huán)執(zhí)行。Vms28資訊網(wǎng)——每日最新資訊28at.com

然后是 useLayoutEffect。Vms28資訊網(wǎng)——每日最新資訊28at.com

const [count, setCount] = useState(0)useLayoutEffect(() => {  document.title = `React ${count}`})

layoutEffect 會在組件渲染之前執(zhí)行。具體的步驟如下圖。Vms28資訊網(wǎng)——每日最新資訊28at.com

Vms28資訊網(wǎng)——每日最新資訊28at.com

但是這里如果只是這樣理解的話,估計很多人并不太清晰具體是怎么回事。因為這樣的表達并沒有說清楚具體的執(zhí)行時刻。更準確的說法是在 commit 之后,組件內(nèi)容繪制呈現(xiàn)到屏幕之前。Vms28資訊網(wǎng)——每日最新資訊28at.com

例如我們有這樣一段代碼。Vms28資訊網(wǎng)——每日最新資訊28at.com

// 此時已經(jīng)對DOM發(fā)送改變的指令div.style.color = 'red'layoutEffect()

layoutEffect 緊隨 DOM 修改指令發(fā)出之后執(zhí)行,此時雖然 DOM 指令已經(jīng)發(fā)出,但是在瀏覽器的機制中,內(nèi)容繪制是一個異步的過程,這會兒繪制并沒有執(zhí)行。Vms28資訊網(wǎng)——每日最新資訊28at.com

因此在事件循環(huán)中,layoutEfect 被定義為類似于 Promise 的微任務(wù),在 DOM 指令修改之后,內(nèi)容繪制之前執(zhí)行。Vms28資訊網(wǎng)——每日最新資訊28at.com

后續(xù)影響

大家可以猜想一下,如果我們在 layoutEffect 中直接去修改 state,會發(fā)生什么事情。Vms28資訊網(wǎng)——每日最新資訊28at.com

看看下面這個例子:Vms28資訊網(wǎng)——每日最新資訊28at.com

function Demo() {  const [count, setCount] = useState(0)    useLayoutEffect(() => {    if (count == 0) {      setCount(1)    }  }, [count])      return (    <div>      <div>{count}</div>      <button         onClick={() => setCount(0)}      >        reset 0      </button>    </div>  )}

我們在 state 中聲明一個變量 count,初始值設(shè)置為 0,并定義 layoutEffect,其中的邏輯就是當 count == 0 時,將 count 設(shè)置為 1。Vms28資訊網(wǎng)——每日最新資訊28at.com

添加一個按鈕,當按鈕點擊時,把 count 重新設(shè)置為 0。Vms28資訊網(wǎng)——每日最新資訊28at.com

大家思考一下,此時,頁面上的顯示結(jié)果,會在 0 和 1 之間來回切換嗎?Vms28資訊網(wǎng)——每日最新資訊28at.com

答案是不會。Vms28資訊網(wǎng)——每日最新資訊28at.com

因為當我們執(zhí)行 layoutEffect 時,UI 并沒有進入事件循環(huán)的繪制流程,此時還處于 JS 邏輯的執(zhí)行過程中,那么這個時候執(zhí)行 setCount,整個邏輯會重新執(zhí)行,對于瀏覽器而言,JS 針對同一個 UI 發(fā)出了兩條不同的指令,在瀏覽器的渲染機制中,也會發(fā)生收集行為,將這兩條指令進行合并,最后只執(zhí)行一條。Vms28資訊網(wǎng)——每日最新資訊28at.com

// setCount(0)div.innerHTML = 0// setCount(1)div.innerHTML = 1

如上例,當 setCount(0) 與 setCount(1)  執(zhí)行完之后,實際上是發(fā)出了兩條修改元素內(nèi)容的指令給到瀏覽器。Vms28資訊網(wǎng)——每日最新資訊28at.com

當我們使用 useLayoutEffect 時他可能會覆蓋你想要執(zhí)行的渲染內(nèi)容,也有可能會阻塞你的正常渲染過程,因此我們在使用它時,需要精確把控他的執(zhí)行時機,防止出現(xiàn)你不想看到的結(jié)果。Vms28資訊網(wǎng)——每日最新資訊28at.com

但是很明顯我們可以看到 layoutEffect 的執(zhí)行時機比 effect 更早。因此我們也可以在 layoutEffect 中,執(zhí)行一些輕量的,不直接影響 state 的邏輯。Vms28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-63227-0.html精準解析 useLayoutEffect 與 useEffect 的執(zhí)行時機

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Java高頻面試題:過濾器和攔截器兩位難兄難弟區(qū)別

下一篇: 這篇文章徹底讓你了解Java與RPA

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
久久阴道视频| 久久久91精品国产一区二区三区 | 亚洲视频碰碰| 亚洲中无吗在线| 久久久精品一品道一区| 久久久五月婷婷| 欧美激情一区二区三区成人| 欧美日韩在线播| 国产女人18毛片水18精品| 激情文学一区| 日韩视频亚洲视频| 午夜精品免费| 噜噜噜在线观看免费视频日韩| 欧美精品网站| 国产精品久久久久久久久婷婷| 国产亚洲一级| 亚洲人成在线播放| 亚洲欧美中文另类| 蜜桃av一区| 国产精品jizz在线观看美国| 国内免费精品永久在线视频| 日韩午夜电影| 欧美在线观看你懂的| 国产一区在线免费观看| 在线看片第一页欧美| 中日韩视频在线观看| 久久精品二区三区| 欧美日韩精品不卡| 国内精品久久久久影院色| 亚洲精选在线观看| 久久精品二区三区| 欧美日韩在线播放三区| 一区免费在线| 亚洲欧美一区二区三区久久| 欧美成人影音| 国产日产高清欧美一区二区三区| 亚洲靠逼com| 久久久五月天| 欧美高清一区| 国内激情久久| 亚洲视频免费观看| 欧美不卡一卡二卡免费版| 国产精品二区三区四区| 亚洲欧洲日本在线| 久久精品在线| 国产精品一区二区男女羞羞无遮挡| 亚洲精品在线视频观看| 久久久综合网站| 国产欧美亚洲日本| 中文日韩在线视频| 欧美精品91| 在线精品国产成人综合| 欧美在线一级视频| 久久久999精品免费| 欧美日韩情趣电影| 亚洲激情网站| 久久久噜噜噜久久中文字免| 国产精品狼人久久影院观看方式| 亚洲国产精品成人一区二区 | 欧美人与性动交α欧美精品济南到| 国产一区二区三区丝袜| 亚洲免费一级电影| 欧美日韩视频在线一区二区观看视频 | 欧美一区日韩一区| 国产精品久久一卡二卡| 亚洲精品在线一区二区| 欧美成人午夜激情在线| 在线成人av网站| 久久久女女女女999久久| 国产亚洲精品v| 午夜综合激情| 国产伦精品一区二区三区照片91| 亚洲免费视频观看| 国产精品区二区三区日本| 99精品热视频| 欧美日韩国产综合新一区| 亚洲精品一品区二品区三品区| 久久先锋资源| 在线观看视频免费一区二区三区| 久久国产免费看| 国产视频久久久久| 久久成人免费日本黄色| 国产一区二区三区成人欧美日韩在线观看 | 性色av一区二区三区| 国产精品日韩精品| 午夜精品久久久久久久白皮肤| 国产精品美女久久久| 尤物九九久久国产精品的分类| 久久久久久一区二区| 狠狠色狠狠色综合人人| 久久综合给合久久狠狠狠97色69| 狠狠久久亚洲欧美专区| 久久久久一本一区二区青青蜜月| 国内精品久久国产| 久久精品国产亚洲一区二区三区| 国产一区三区三区| 浪潮色综合久久天堂| 亚洲观看高清完整版在线观看| 欧美96在线丨欧| 日韩天堂在线视频| 国产精品久久7| 欧美在线资源| 亚洲成色www8888| 欧美激情中文不卡| 亚洲午夜91| 国产一区二区三区四区在线观看| 久久亚洲免费| 亚洲每日更新| 国产精品午夜在线观看| 亚洲欧洲日本在线| 欧美日韩久久| 亚洲欧美日韩国产中文 | 国产日韩欧美综合| 久久尤物视频| 亚洲三级观看| 国产精品成人一区二区三区吃奶| 亚洲欧美日韩精品综合在线观看| 国产一区二区日韩精品| 欧美成人午夜激情| 亚洲一区二区精品视频| 欧美暴力喷水在线| 亚洲精品黄网在线观看| 国产精品福利网| 久久精品主播| 日韩午夜中文字幕| 国产欧美日本一区二区三区| 久久性天堂网| 亚洲无毛电影| 国内精品视频久久| 欧美精品免费在线| 午夜综合激情| 亚洲黄色小视频| 国产精品卡一卡二卡三| 久久免费99精品久久久久久| 日韩视频一区二区| 国产日韩欧美一区二区三区四区| 免费成人激情视频| 亚洲男女自偷自拍图片另类| 在线日韩中文字幕| 国产精品久久99| 蜜臀a∨国产成人精品| 亚洲影音一区| 亚洲激情另类| 国产欧美日韩伦理| 欧美精品999| 久久激情一区| 亚洲私拍自拍| 亚洲黄色有码视频| 国产视频欧美视频| 欧美日韩亚洲视频| 毛片精品免费在线观看| 亚洲欧美国产制服动漫| 亚洲人体大胆视频| 国产综合色精品一区二区三区| 欧美日韩国产一区二区三区地区| 久久久久青草大香线综合精品| 亚洲手机成人高清视频| 亚洲国产天堂久久国产91| 国产人久久人人人人爽| 欧美久久99| 狼人社综合社区| 香蕉成人久久| 一区二区三区成人| 亚洲欧洲精品一区二区三区波多野1战4| 国产欧美日韩亚州综合| 欧美日韩直播| 欧美顶级艳妇交换群宴| 久久久久久噜噜噜久久久精品| 亚洲女优在线| 亚洲私拍自拍| 日韩一区二区免费高清| 在线看国产一区| 国内精品久久久久影院 日本资源| 国产精品久久久久久久久搜平片 | 一区在线影院| 国产欧美一区二区精品忘忧草 | 欧美大片免费观看| 久久久综合网站| 欧美中文字幕在线播放| 亚洲欧美国产一区二区三区| 一区二区三区黄色| 亚洲精品中文字幕在线观看| 影音先锋久久| 国内外成人在线| 国产拍揄自揄精品视频麻豆| 国产精品久久久久久一区二区三区| 欧美激情乱人伦| 欧美大片va欧美在线播放| 久久免费的精品国产v∧| 久久久999精品免费| 欧美在线视频在线播放完整版免费观看| 亚洲一级特黄| 亚洲一区二区少妇| 亚洲香蕉网站| 亚洲一二三区在线| 亚洲综合大片69999| 亚洲一区影音先锋| 亚洲一区二区三区777| 亚洲性色视频| 午夜精品影院| 欧美专区18| 久久久91精品| 蜜臀av一级做a爰片久久| 猛干欧美女孩|