記錄React使用connect后,ref.current為null問題及解決
問題
在用React開發(fā)項目的過程中,遇到一個問題,使用connect連接低階組件包裝成高階組件HOC后,父組件通用ref調(diào)用子組件方法時,提示xxxRef.current為null的錯誤。
代碼如下:
// 子組件 // 通過connect方式連接為高階組件 export default connect( ? ? mapStateToProps, )(ComboSelectorForm);
// 父組件
constructor(props: IComboSelectorListProps | Readonly<IComboSelectorListProps>) {
? ? super(props);
? ? // ...
? ? this.formRef = React.createRef();
? ? // ...
}
// 組件掛載在formRef上
<ComboSelectorForm
? ? ref={this.formRef}
? ? id={this.state.id}
? ? onSaveSuccess={this.handleSaveSuccess}
>
</ComboSelectorForm>
// 調(diào)用子組件方法
this.formRef.current.methodName();父組件調(diào)用子組件方法后,報以下錯誤
TypeError: Cannot read properties of null (reading 'methodName')
解析
React的高階組件HOC,可以理解成在低階組件上進行一些封裝。
高階組件HOC如果不做一些特殊處理,是無法直接訪問低階組件實例的,要想通過ref訪問低階組件實例,調(diào)用connect時,需要傳遞參數(shù){forwardRef : true}。
connect方法有四個參數(shù),官方文檔是這樣說明的:
mapStateToProps?: FunctionmapDispatchToProps?: Function | ObjectmergeProps?: Functionoptions?: Object
對于前面三個參數(shù)先不展開來講解,主要第四個options參數(shù),有以下幾個屬性:
{
? context?: Object,
? pure?: boolean,
? areStatesEqual?: Function,
? areOwnPropsEqual?: Function,
? areStatePropsEqual?: Function,
? areMergedPropsEqual?: Function,
? forwardRef?: boolean,
}其中最后一個參數(shù)forwardRef正是我們的主角,官方文檔里這樣解釋:
If {forwardRef : true} has been passed to connect, adding a ref to the connected wrapper component will actually return the instance of the wrapped component.
當該參數(shù)forwardRef設置為true時,包裹組件(wrapper component )的ref屬性將會實際返回被包裹組件(wrapped component)實例。
OS:原諒我翻譯水平有限。(>_<)
最終解決方案
直接上代碼:
// 子組件
// 通過connect方式連接為高階組件
export default connect(
? ? mapStateToProps,
? ? null,?? ?// 新加參數(shù)
? ? null,?? ?// 新加參數(shù)
? ? { forwardRef: true }?? ?// 新加參數(shù)
)(ComboSelectorForm);// 父組件,與之前代碼一致
constructor(props: IComboSelectorListProps | Readonly<IComboSelectorListProps>) {
? ? super(props);
? ? // ...
? ? this.formRef = React.createRef();
? ? // ...
}
// 組件掛載在formRef上
<ComboSelectorForm
? ? ref={this.formRef}
? ? id={this.state.id}
? ? onSaveSuccess={this.handleSaveSuccess}
>
</ComboSelectorForm>
// 調(diào)用子組件方法
this.formRef.current.methodName();通過以上改造后,父組件能夠正常訪問ref實例。
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
windows下create-react-app 升級至3.3.1版本踩坑記
這篇文章主要介紹了windows下create-react-app 升級至3.3.1版本踩坑記,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-02-02
React中使用async validator進行表單驗證的實例代碼
react上進行表單驗證是很繁瑣的,在這里使用async-validator處理起來就變的很方便了,接下來通過本文給大家介紹React中使用async validator進行表單驗證的方法,需要的朋友可以參考下2018-08-08
React18中請求數(shù)據(jù)的官方姿勢適用其他框架
這篇文章主要為大家介紹了官方回答在React18中請求數(shù)據(jù)的正確姿勢詳解,同樣也適用其他框架,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07
React在Dva項目中創(chuàng)建并引用頁面局部組件的方式
這篇文章主要介紹了React在Dva項目中創(chuàng)建并引用頁面局部組件的方式,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07

