網(wǎng)站首頁 編程語言 正文
useEffect 介紹
如果你熟悉 React class 的生命周期函數(shù),你可以把 useEffect Hook 看做
componentDidMount,componentDidUpdate 和 componentWillUnmount 這三個(gè)函數(shù)的組合。
- componentDidMount 組件掛載
- componentDidUpdate 組件更新
- componentWillUnmount 組件將要摧毀
使用方法
情況一:
useEffect需要傳遞兩個(gè)參數(shù),第一個(gè)參數(shù)是邏輯處理函數(shù),第二個(gè)參數(shù)是一個(gè)數(shù)組
代碼如下:
useEffect(() => {
/** 執(zhí)行邏輯 */
},[])
情況二:
- 第二個(gè)參數(shù)存放變量,當(dāng)數(shù)組存放變量發(fā)生改變時(shí),第一個(gè)參數(shù),邏輯處理函數(shù)將會(huì)被執(zhí)行
- 第二個(gè)參數(shù)可以不傳,不會(huì)報(bào)錯(cuò),但瀏覽器會(huì)無限循環(huán)執(zhí)行邏輯處理函數(shù)。
代碼如下:
useEffect(() => {
/** 執(zhí)行邏輯 */
})
情況三:
第二個(gè)參數(shù)如果只傳一個(gè)空數(shù)組,邏輯處理函數(shù)里面的邏輯只會(huì)在組件掛載時(shí)執(zhí)行一次 ,等價(jià)于 componentDidMount
代碼如下:
useEffect(() => {
/** 執(zhí)行邏輯 */
},[])
情況四:
- 第二個(gè)參數(shù)如果不為空數(shù)組,依賴指定參數(shù)觸發(fā)使用
- 邏輯處理函數(shù)會(huì)在組件掛載時(shí)執(zhí)行一次和(a或者b變量在棧中的值發(fā)生改變時(shí)執(zhí)行一次) 這是不是相當(dāng)于componentDidMount 和componentDidUpdate 的結(jié)合
const [a, setA] = useState(1);
const [b, setB] = useState(2);
useEffect(() => {
/** 執(zhí)行邏輯 */
},[a,b])
情況五:
- useEffect第一個(gè)參數(shù)可以返回一個(gè)回調(diào)函數(shù),這個(gè)回調(diào)函數(shù)將會(huì)在組件被摧毀之前和再一次觸發(fā)更新時(shí),將之前的副作用清除掉。這就相當(dāng)于componentWillUnmount。
- useEffect去除副作用。我們可能會(huì)在組件即將被掛載的時(shí)候創(chuàng)建一些不斷循環(huán)的訂閱(計(jì)時(shí)器,或者遞歸循環(huán))。在組件被摧毀之前,或者依賴數(shù)組的元素更新后,應(yīng)該將這些訂閱也給摧毀掉。
比如以下的情況(沒有去除計(jì)時(shí)器,增大不必要的開銷和代碼風(fēng)險(xiǎn))
const [time, setTime] = useState(0)
useEffect(() => {
const InterVal = setInterval(() => {
setTime(time + 1)
},1000)
},[])
處理在組件被摧毀前去除計(jì)時(shí)器
const [time, setTime] = useState(0)
useEffect(() => {
const InterVal = setInterval(() => {
setTime(time + 1)
},1000)
return () => {
clearInterval(InterVal )
}
},[])
特殊情況處理
useEffect監(jiān)測(cè)不到依賴數(shù)組元素的變化。
只有一種可能,依賴數(shù)組元素的地址的值根本就沒變,
原因:因?yàn)閏hangeA沒有真正的改變a在棧中的值(地址的值),只是改變了a在堆中的值。
useEffect監(jiān)測(cè)不到堆中值得變化,所有引用類型數(shù)據(jù)都應(yīng)該注意這一點(diǎn)。
代碼示例:
const [a, setA] = useState({
b: 'dx',
c: '18',
})
const changeA = () => {
setA((old) => {
old.b = 'yx'
return old
})
}
useEffect(() => {
/** 當(dāng)組件掛載時(shí)執(zhí)行一次changeA */
changeA ()
},[])
/**當(dāng)changeA執(zhí)行卻沒有打印 a*/
useEffect(() => {
/** 執(zhí)行邏輯 */
console.log(a)
},[a])
解決的辦法
const [a, setA] = useState({
b: 'dx',
c: '18',
})
const changeA = () => {
setA((old) => {
const newA = {...old}
newA .b = 'yx'
return newA
})
}
useEffect(() => {
/** 當(dāng)組件掛載時(shí)執(zhí)行一次changeA */
changeA ()
},[])
/**當(dāng)changeA執(zhí)行打印 {b:'yx',c:'18'} */
useEffect(() => {
/** 執(zhí)行邏輯 */
console.log(a)
},[a])
原文鏈接:https://blog.csdn.net/weixin_50636536/article/details/128379079
相關(guān)推薦
- 2022-06-23 教你編寫bat腳本W(wǎng)indows批處理_DOS/BAT
- 2022-06-29 C語言實(shí)例講解四大循環(huán)語句的使用_C 語言
- 2022-04-11 error: failed to push some refs to 遠(yuǎn)程倉庫地址 怎么解決
- 2022-04-28 WPF使用Canvas畫布面板布局_實(shí)用技巧
- 2022-03-22 Linux系統(tǒng)下gcc命令使用詳解_Linux
- 2022-06-01 Apache?Hudi靈活的Payload機(jī)制硬核解析_服務(wù)器其它
- 2022-12-28 jQuery如何設(shè)置背景顏色_jquery
- 2023-07-22 macos設(shè)置環(huán)境變量path詳解
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支