React中super()和super(props)的區(qū)別小結(jié)
1. ES6類
在ES6中,通過extends關(guān)鍵字實(shí)現(xiàn)類的繼承,方式如下:
class sup{
constructor(name){
this.name=name;
}
printName(){
console.log(this.name)
}
}
class sub extends sup{
constructor(name,age){
super(name) //super 代表的是父類的構(gòu)造函數(shù)
this.age=age;
}
printAge(){
console.log(this.age)
}
}
let rui=new sub('rui',21);
rui.printAge() //21
rui.printName() //rui
在上面的例子在子中,可以看到通過super關(guān)鍵字實(shí)現(xiàn)調(diào)用父類,super代替的是父類的構(gòu)建函數(shù),使用super(name)相當(dāng)于調(diào)sup.prototype.constructor.call(this.name)
如果在子類中不使用super關(guān)鍵字,則會(huì)引發(fā)報(bào)錯(cuò)
報(bào)錯(cuò)的原因是 子類沒有自己的this對(duì)象,它只能繼承父類的this對(duì)象,然后對(duì)其進(jìn)行加工而super()就是將父類中的this對(duì)象繼承給子類的,沒有super()子類就得不到this對(duì)象
如果先調(diào)用this ,再初始化super(),同樣是禁止的行為
所以在子類的constructor 中 ,必須先用super 才能引用this
2. 類組件
在React中,類組件是基于es6的規(guī)范實(shí)現(xiàn)的,繼承React.Component,因此如果用到constructor就必須寫super()才初始化this
這時(shí)候,在調(diào)用super()的時(shí)候,我們一般都需要傳入props作為參數(shù),如果傳不進(jìn)去,React內(nèi)部也會(huì)將其定義在組件實(shí)例中
// React 內(nèi)部 const instance = new YourComponent(props); instance.props = props;
所以無論有沒有constructor,在render中this.props都是可以使用的,這是React自動(dòng)附帶的,是可以不寫的
class HelloMessage extends React.Component{
render(){
return <div>hello {this.props.name}</div>
}
}
但是也不建議使用super()代替super(props)因?yàn)樵赗eact會(huì)在類組件構(gòu)造函數(shù)生成實(shí)例后再給this.props附值,所以 不傳遞props在super的情況下,調(diào)用this.props為undefined,情況如下:
class Button extends React.Component{
constructor(props){
super() //沒傳入props
console.log(props) //{}
console.log(this.props) //undefined
}
}
而傳入props的則都能正常訪問,確保了this.props在構(gòu)造函數(shù)執(zhí)行完畢之前已經(jīng)被賦值,更符合邏輯
class Button extends React.Component{
constructor(props){
super(props) /
console.log(props) //{}
console.log(this.props) //{}
}
}
3. 總結(jié)
在React 中,類組件基于ES6,所以在constructor中必須使用super在調(diào)用super過程,無論是否傳入props,React內(nèi)部都會(huì)將props賦值給組件實(shí)例props屬性中,如果調(diào)用了super(),那么this.props在super和構(gòu)造函數(shù)結(jié)束之間仍然是undefined
到此這篇關(guān)于React中super()和super(props)的區(qū)別小結(jié)的文章就介紹到這了,更多相關(guān)React super()和super(props)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react-router browserHistory刷新頁面404問題解決方法
本篇文章主要介紹了react-router browserHistory刷新頁面404問題解決方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-12-12
React實(shí)現(xiàn)歌詞滾動(dòng)效果(跟隨音樂播放時(shí)間滾動(dòng))
這篇文章主要為大家詳細(xì)介紹了React實(shí)現(xiàn)歌詞滾動(dòng)效果(跟隨音樂播放使勁按滾動(dòng)),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2024-02-02
React關(guān)于antd table中select的設(shè)值更新問題
這篇文章主要介紹了React關(guān)于antd table中select的設(shè)值更新問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
React?Native性能優(yōu)化指南及問題小結(jié)
本文將介紹在React?Native開發(fā)中常見的性能優(yōu)化問題和解決方案,包括ScrollView內(nèi)無法滑動(dòng)、熱更新導(dǎo)致的文件引用問題、高度獲取、強(qiáng)制橫屏UI適配、低版本RN適配iOS14、緩存清理、navigation參數(shù)取值等,感興趣的朋友一起看看吧2024-01-01
使用 Rails API 構(gòu)建一個(gè) React 應(yīng)用程序的詳細(xì)步驟
這篇文章主要介紹了使用 Rails API 構(gòu)建一個(gè) React 應(yīng)用程序的詳細(xì)步驟,主要包括后端:Rails API部分,前端:React部分及React組件的相關(guān)操作,具有內(nèi)容詳情跟隨小編一起看看吧2021-08-08
react18中react-redux狀態(tài)管理的實(shí)現(xiàn)
本文主要介紹了react18中react-redux狀態(tài)管理的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05
解析react?函數(shù)組件輸入卡頓問題?usecallback?react.memo
useMemo是一個(gè)react hook,我們可以使用它在組件中包裝函數(shù)。可以使用它來確保該函數(shù)中的值僅在依賴項(xiàng)之一發(fā)生變化時(shí)才重新計(jì)算,這篇文章主要介紹了react?函數(shù)組件輸入卡頓問題?usecallback?react.memo,需要的朋友可以參考下2022-07-07

