2個奇怪的react寫法
ref的奇怪用法
這是一段初看讓人很困惑的代碼:
function App() {
const [dom, setDOM] = useState(null);
return <div ref={setDOM}></div>;
}讓我們來分析下它的作用。
首先,ref有兩種形式(曾經有3種):
- 形如
{current: T}的數據結構 - 回調函數形式,會在
ref更新、銷毀時觸發(fā)
例子中的setDOM是useState的dispatch方法,也有兩種調用形式:
- 直接傳遞更新后的值,比如
setDOM(xxx) - 傳遞更新狀態(tài)的方法,比如
setDOM(oldDOM => return /* 一些處理邏輯 */)
在例子中,雖然反常,但ref的第二種形式和dispatch的第二種形式確實是契合的。
也就是說,在例子中傳遞給ref的setDOM方法,會在div對應DOM更新、銷毀時執(zhí)行,那么dom狀態(tài)中保存的就是div對應DOM的最新值。
這么做一定程度上實現了感知DOM的實時變化,這是單純使用ref無法具有的能力。
useMemo的奇怪用法
通常我們認為useMemo用來緩存變量props,useCallback用來緩存函數props。
但在實際項目中,如果想通過緩存props的方式達到子組件性能優(yōu)化的目的,需要同時保證:
- 所有傳給子組件的
props的引用都不變(比如通過useMemo) - 子組件使用
React.memo
類似這樣:
function App({todos, tab}) {
const visibleTodos = useMemo(
() => filterTodos(todos, tab),
[todos, tab]);
return <Todo data={visibleTodos}/>;
}
// 為了達到Todo性能優(yōu)化的目的
const Todo = React.memo(({data}) => {
// ...省略邏輯
})既然useMemo可以緩存變量,為什么不直接緩存組件的返回值呢?類似這樣:
function App({todos, tab}) {
const visibleTodos = useMemo(
() => filterTodos(todos, tab),
[todos, tab]);
return useMemo(() => <Todo data={visibleTodos}/>, [visibleTodos])
}
function Todo({data}) {
return <p>{data}</p>;
}如此,需要性能優(yōu)化的子組件不再需要手動包裹React.memo,只有當useMemo依賴變化后子組件才會重新render。
總結
除了這兩種奇怪的寫法外,你還遇到哪些奇怪的React寫法呢?
相關文章
react-native 配置@符號絕對路徑配置和絕對路徑沒有提示的問題
本文主要介紹了react-native 配置@符號絕對路徑配置和絕對路徑沒有提示的問題,文中通過圖文示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-01-01
React報錯信息之Expected?an?assignment?or?function?call?and?
這篇文章主要介紹了React報錯之Expected?an?assignment?or?function?call?and?instead?saw?an?expression,下面有兩個示例來展示錯誤是如何產生的,需要的朋友可以參考下2022-08-08
詳解React中傳入組件的props改變時更新組件的幾種實現方法
這篇文章主要介紹了詳解React中傳入組件的props改變時更新組件的幾種實現方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09
React 進入頁面后自動 focus 到某個輸入框的解決方案
React.js 當中提供了 ref 屬性來幫助我們獲取已經掛載的元素的 DOM 節(jié)點,你可以給某個 JSX 元素加上 ref屬性,這篇文章主要介紹了React 進入頁面以后自動 focus 到某個輸入框,需要的朋友可以參考下2024-02-02

