日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

記錄React使用connect后,ref.current為null問題及解決

瀏覽:322日期:2022-06-10 09:29:41
目錄
  • 問題
  • 解析
  • 最終解決方案
  • 總結

問題

在用React開發項目的過程中,遇到一個問題,使用connect連接低階組件包裝成高階組件HOC后,父組件通用ref調用子組件方法時,提示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>
// 調用子組件方法
this.formRef.current.methodName();

父組件調用子組件方法后,報以下錯誤

TypeError: Cannot read properties of null (reading 'methodName')

解析

React的高階組件HOC,可以理解成在低階組件上進行一些封裝。

高階組件HOC如果不做一些特殊處理,是無法直接訪問低階組件實例的,要想通過ref訪問低階組件實例,調用connect時,需要傳遞參數{forwardRef : true}。

connect方法有四個參數,官方文檔是這樣說明的:

  • mapStateToProps?: Function
  • mapDispatchToProps?: Function | Object
  • mergeProps?: Function
  • options?: Object

對于前面三個參數先不展開來講解,主要第四個options參數,有以下幾個屬性:

{
? context?: Object,
? pure?: boolean,
? areStatesEqual?: Function,
? areOwnPropsEqual?: Function,
? areStatePropsEqual?: Function,
? areMergedPropsEqual?: Function,
? forwardRef?: boolean,
}

其中最后一個參數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.

當該參數forwardRef設置為true時,包裹組件(wrapper component )的ref屬性將會實際返回被包裹組件(wrapped component)實例。

OS:原諒我翻譯水平有限。(>_<)

最終解決方案

直接上代碼:

// 子組件
// 通過connect方式連接為高階組件
export default connect(
? ? mapStateToProps,
? ? null,?? ?// 新加參數
? ? null,?? ?// 新加參數
? ? { forwardRef: true }?? ?// 新加參數
)(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>
// 調用子組件方法
this.formRef.current.methodName();

通過以上改造后,父組件能夠正常訪問ref實例。

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持。

標簽: JavaScript
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲欧美视频| 日本在线不卡视频一二三区| 日韩不卡一区二区| 日韩国产成人精品| 国产色噜噜噜91在线精品| 欧美日韩一区二区三区四区在线观看| 日本成人在线不卡视频| 欧美日韩一区二区高清| 久久精品国产成人一区二区三区| 麻豆国产精品一区二区三区| 美女视频免费精品| 老牛影视精品| 伊人久久亚洲影院| 日韩国产欧美在线视频| 伊人精品久久| 日本综合精品一区| 欧美日韩91| 久久精品国产亚洲aⅴ| 视频小说一区二区| 九色porny丨国产首页在线| 国产视频亚洲| 深夜福利一区| 国产精品久久久久久久久久久久久久久 | 日韩动漫一区| 国产乱人伦丫前精品视频| 欧美天堂在线| 午夜精品久久久久久久久久蜜桃| 亚洲午夜一级| 综合日韩在线| 国产中文字幕一区二区三区| 久久久国产精品一区二区中文| 亚洲精品午夜av福利久久蜜桃| 亚洲精品字幕| 精品视频高潮| 日韩影院精彩在线| 91精品麻豆| caoporn视频在线| 国产精品白浆| 国产理论在线| 综合亚洲视频| 久久精品国语| 成人在线黄色| 国产精品久久国产愉拍| 在线看片日韩| 国产精品av久久久久久麻豆网| 美女久久99| 国产欧美大片| 久久香蕉精品| 亚洲在线电影| 伊人久久婷婷| japanese国产精品| 色婷婷精品视频| 精品亚洲成人| 国产欧美一区二区精品久久久 | 国产一区二区三区不卡视频网站| 亚洲精品九九| 亚洲区欧美区| 日韩国产欧美视频| 国产情侣久久| 麻豆精品视频在线观看| 国产精品久久久久9999高清| 国产毛片精品| 久久精品人人| 黄毛片在线观看| 999久久久91| 久久久久久久久丰满| 国产激情久久| 91精品视频一区二区| 久久久精品五月天| 国产传媒在线观看| 久久婷婷av| 日韩精品亚洲专区| 国产一区二区三区不卡视频网站| 久久中文字幕av一区二区不卡| 男人的天堂久久精品| 精品资源在线| 蜜臀精品久久久久久蜜臀| 久久精品天堂| 免费精品视频| 精品国产亚洲一区二区三区大结局| 亚洲成人二区| 蜜桃一区二区三区在线| 久久中文欧美| 香蕉久久久久久| 亚洲激情精品| 亚洲伦乱视频| 国产伦精品一区二区三区视频| 久久久精品午夜少妇| 国产一区二区三区久久| 日韩免费福利视频| 99精品国产一区二区三区| 久久国产高清| 丁香婷婷久久| 免费人成精品欧美精品| 国产精品入口久久| 欧美粗暴jizz性欧美20| 日韩午夜一区| 国产精品久久久免费| 亚洲一级在线| 久久久久久黄| 精品一二三区| 亚洲欧美网站在线观看| 日韩免费av| 精品黄色一级片| 青草久久视频| 欧美在线影院| 国产欧美一区二区三区精品酒店 | 久久性天堂网| 国产精品av一区二区| 免费在线播放第一区高清av| 国产成人精品亚洲线观看| 色综合视频一区二区三区日韩| 99久久精品网| 日韩一区自拍| 久久香蕉网站| 国产精品第十页| 香蕉成人久久| 美女网站视频一区| 成人污污视频| 欧美精品二区| 国产精品欧美三级在线观看| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美日韩在线二区| 91精品一区二区三区综合| 国产欧美自拍一区| 69精品国产久热在线观看| 日本欧美大码aⅴ在线播放| 久久午夜精品| 日韩精品中文字幕一区二区| 综合一区在线| 欧美在线看片| 国产日韩欧美一区| 国产精品激情| 91视频久久| 99久久九九| 日av在线不卡| 欧美亚洲tv| 国产精品日本一区二区不卡视频| 欧美激情三区| 久久久精品区| 女生影院久久| 蘑菇福利视频一区播放| 五月亚洲婷婷 | 福利一区二区| 99久久99久久精品国产片果冰| 久久在线电影| 日本大胆欧美人术艺术动态| 日本不卡的三区四区五区| 欧美韩一区二区| 色爱综合av| 日韩在线黄色| 欧美日一区二区在线观看| 国产精品成人自拍| 欧美aa在线观看| 亚洲大全视频| 欧美欧美黄在线二区| 92国产精品| 亚洲精品成a人ⅴ香蕉片| 国内精品亚洲| 亚洲精品九九| 国产一区清纯| 老司机免费视频一区二区三区| 亚洲国产成人精品女人| 国产精品a久久久久| 久久99伊人| 久久国产影院| 国产精品tv| 国产一区导航| 久久男女视频| 精品视频在线你懂得| 亚洲欧洲日韩| 影音先锋久久| 色在线视频观看| 精品国产亚洲一区二区三区| 日韩中文字幕不卡| 午夜精品一区二区三区国产| 国产日产一区| 日韩高清中文字幕一区| 国产亚洲在线观看| 亚洲二区视频| 日韩毛片视频| 国产经典一区| 欧美一级一区| 日韩一区二区三区精品| 亚洲综合日韩| 亚洲精品97| 国产综合色产| 日韩av电影一区| 91成人精品| 国产亚洲高清视频| 一区福利视频| 亚洲在线一区| 免费人成网站在线观看欧美高清| 国产99久久久国产精品成人免费| 欧美精选视频一区二区| 日韩大片在线播放| 久久精品国产99国产| 精品网站999| www.51av欧美视频| 久久中文字幕二区|