亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

uesRef

有點抄文檔的感覺啊 花了錢的? 感覺細節講的不是很深入 講的不是很深入 例如 useRef那一節為什么不用ref就會獲取不到值

正在回答

1 回答

好吧,為了彌補,就在這里做回答吧,先看下代碼實現

const?[num,?setNum]?=?useState(1)

let?timer

//?第一個effect
useEffect(()?=>?{
??timer?=?setInterval(()?=>?{
????console.log(1111);
????setNum(num?+?1)
??},?400)
},?[])
//?第二個effect
useEffect(()?=>?{
??console.log(num,?timer);
},?[num])

return?(
??<div?className="App">
????{num}
??</div>
);

第一個effect在更新渲染的時候,并沒有依賴num參數,也就是只執行一次就結束了,但是每次更新num的時候,當前組件是要刷新的,timer也會重新生成一個,此時的timer只是undefined,并沒有賦值的過程(第一個effect不執行了)。第一次給timer賦值之后,剩下的所有更新里,timer都是undefined。所以在第二個effect里獲取和清空timer,只能獲取到undefined。

如果還有不明白,歡迎再次提問。?

3 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
React Hooks2小時快速入門
  • 參與學習       2716    人
  • 解答問題       22    個

React Hooks 入門的不二之選

進入課程
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號