欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React中super()和super(props)的區(qū)別小結(jié)

 更新時間:2024年03月11日 09:41:40   作者:前端小超人rui  
本文主要介紹了React中super()和super(props)的區(qū)別小結(jié),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

1. ES6類

在ES6中,通過extends關(guān)鍵字實現(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)鍵字實現(xiàn)調(diào)用父類,super代替的是父類的構(gòu)建函數(shù),使用super(name)相當于調(diào)sup.prototype.constructor.call(this.name)

如果在子類中不使用super關(guān)鍵字,則會引發(fā)報錯
報錯的原因是 子類沒有自己的this對象,它只能繼承父類的this對象,然后對其進行加工而super()就是將父類中的this對象繼承給子類的,沒有super()子類就得不到this對象

如果先調(diào)用this ,再初始化super(),同樣是禁止的行為
所以在子類的constructor 中 ,必須先用super 才能引用this

2. 類組件

在React中,類組件是基于es6的規(guī)范實現(xiàn)的,繼承React.Component,因此如果用到constructor就必須寫super()才初始化this

這時候,在調(diào)用super()的時候,我們一般都需要傳入props作為參數(shù),如果傳不進去,React內(nèi)部也會將其定義在組件實例中

// React 內(nèi)部
const instance = new YourComponent(props);
instance.props = props;

所以無論有沒有constructor,在render中this.props都是可以使用的,這是React自動附帶的,是可以不寫的

class HelloMessage extends React.Component{
    render(){
        return <div>hello {this.props.name}</div>
    }
}

但是也不建議使用super()代替super(props)因為在React會在類組件構(gòu)造函數(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)部都會將props賦值給組件實例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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • react-router browserHistory刷新頁面404問題解決方法

    react-router browserHistory刷新頁面404問題解決方法

    本篇文章主要介紹了react-router browserHistory刷新頁面404問題解決方法,非常具有實用價值,需要的朋友可以參考下
    2017-12-12
  • React實現(xiàn)歌詞滾動效果(跟隨音樂播放時間滾動)

    React實現(xiàn)歌詞滾動效果(跟隨音樂播放時間滾動)

    這篇文章主要為大家詳細介紹了React實現(xiàn)歌詞滾動效果(跟隨音樂播放使勁按滾動),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2024-02-02
  • react中antd文本框限制輸入中文方式

    react中antd文本框限制輸入中文方式

    這篇文章主要介紹了react中antd文本框限制輸入中文方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • React useEffect使用教程

    React useEffect使用教程

    useEffect是react v16.8新引入的特性。我們可以把useEffect hook看作是componentDidMount、componentDidUpdate、componentWillUnmounrt三個函數(shù)的組合
    2022-10-10
  • React關(guān)于antd table中select的設(shè)值更新問題

    React關(guān)于antd table中select的設(shè)值更新問題

    這篇文章主要介紹了React關(guān)于antd table中select的設(shè)值更新問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • React?Native性能優(yōu)化指南及問題小結(jié)

    React?Native性能優(yōu)化指南及問題小結(jié)

    本文將介紹在React?Native開發(fā)中常見的性能優(yōu)化問題和解決方案,包括ScrollView內(nèi)無法滑動、熱更新導(dǎo)致的文件引用問題、高度獲取、強制橫屏UI適配、低版本RN適配iOS14、緩存清理、navigation參數(shù)取值等,感興趣的朋友一起看看吧
    2024-01-01
  • 使用 Rails API 構(gòu)建一個 React 應(yīng)用程序的詳細步驟

    使用 Rails API 構(gòu)建一個 React 應(yīng)用程序的詳細步驟

    這篇文章主要介紹了使用 Rails API 構(gòu)建一個 React 應(yīng)用程序的詳細步驟,主要包括后端:Rails API部分,前端:React部分及React組件的相關(guān)操作,具有內(nèi)容詳情跟隨小編一起看看吧
    2021-08-08
  • react18中react-redux狀態(tài)管理的實現(xiàn)

    react18中react-redux狀態(tài)管理的實現(xiàn)

    本文主要介紹了react18中react-redux狀態(tài)管理的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • 解析react?函數(shù)組件輸入卡頓問題?usecallback?react.memo

    解析react?函數(shù)組件輸入卡頓問題?usecallback?react.memo

    useMemo是一個react hook,我們可以使用它在組件中包裝函數(shù)??梢允褂盟鼇泶_保該函數(shù)中的值僅在依賴項之一發(fā)生變化時才重新計算,這篇文章主要介紹了react?函數(shù)組件輸入卡頓問題?usecallback?react.memo,需要的朋友可以參考下
    2022-07-07
  • React?Suspense前后端IO異步操作處理

    React?Suspense前后端IO異步操作處理

    這篇文章主要為大家介紹了React?Suspense前后端IO異步操作處理示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06

最新評論