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

react組件中的constructor和super知識點整理

 更新時間:2021年08月17日 09:44:28   作者:一直在尋  
這篇文章主要介紹了react組件中的constructor和super知識點整理,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

1、react中用class申明的類一些小知識

如上圖:類Child是通過class關(guān)鍵字申明,并且繼承于類React。

A、Child的類型是? typeofChild === 'function' , 其實就相當于ES5用function申明的構(gòu)造函數(shù) function Child() { //申明構(gòu)造函數(shù) }

B、Child類調(diào)用時候( new Child() ),會優(yōu)先執(zhí)行,并且自動執(zhí)行Child的constructor函數(shù)。

constructor() {
   console.log('執(zhí)行了constructor')
       return 'hah'
   }

   getName() {
       console.log('執(zhí)行了方法')
   }
}
var dd = new Person();
console.log(dd)

打印如下:

3、Child類中的this? this指向Child的實例,相當于 new Child() 那么它們完全相等嗎? 不是的,react中的this是在new Child()基礎(chǔ)上進行了包裹(下圖)。

上圖為new Child() 下圖為 Child中的this

結(jié)論:this是在new Child()基礎(chǔ)上進行了包裹,包含了一些react內(nèi)部方法,

同時組件中使用Child類( <div> <Child /> </div> ),可以看成 new Child() + react包裹。(細節(jié)待追究。。。)

2、組件中的constructor是否有必要? 如果沒有呢??作用呢???

ES6的知識補充: http://es6.ruanyifeng.com/ 如下:

class ColorPoint extends Point {
}

// 等同于 
class ColorPoint extends Point {
  constructor(...args) {
    super(...args);
  }
}
// 可見沒有寫constructor,在執(zhí)行過程中會自動補上

由ES6的繼承規(guī)則得知,不管子類寫不寫constructor,在new實例的過程都會給補上constructor。

所以:constructor鉤子函數(shù)并不是不可缺少的,子組件可以在一些情況略去。

接下來,繼續(xù)看下有沒有constructor鉤子函數(shù)有什么區(qū)別:

A、先看有無constructor鉤子函數(shù)的 this.constructor

有constructor鉤子函數(shù)的 this.constructor

無constructor鉤子函數(shù)的 this.constructor

如果能看細節(jié)的話,會得知有constructor鉤子函數(shù)時候,Child類會多一個constructor方法。

B、再看有無先看有無constructor鉤子函數(shù)的 this,也就是組件實例。

有constructor鉤子函數(shù)的 this實例。

無constructor鉤子函數(shù)的 this實例。

會得知有constructor鉤子函數(shù)時候,可以定義state,如果用戶不定義state的話,有無constructor鉤子函數(shù)時候沒有區(qū)別。

結(jié)論: 如果組件要定義自己的state初始狀態(tài)的話,需要寫在constructor鉤子函數(shù)中,

如果用戶不使用state的話,純用props接受參數(shù),有沒有constructor鉤子函數(shù)都可以,可以不用constructor鉤子函數(shù)。

再者如果不使用state,那么為什么不使用 無狀態(tài)組件(建議使用)呢???

3、super中的props是否必要? 作用是什么??

有的小伙伴每次寫組件都會習慣性在constructor和super中寫上props,那么這個是必要的嗎??

如圖:

首先要明確很重要的一點就是:

可以不寫constructor,一旦寫了constructor,就必須在此函數(shù)中寫super(),

此時組件才有自己的this,在組件的全局中都可以使用this關(guān)鍵字,

否則如果只是constructor 而不執(zhí)行 super() 那么以后的this都是錯的!??!

來源ES6 :http://es6.ruanyifeng.com/

但是super中必須寫參數(shù)props嗎?? 答案是不一定,先看代碼:

有props:

無props:

可以得出結(jié)論:當想在constructor中使用this.props的時候,super需要加入(props),

此時用props也行,用this.props也行,他倆都是一個東西。(不過props可以是任意參數(shù),this.props是固定寫法)。

如圖:

如果在custructor生命周期不使用 this.props或者props時候,可以不傳入props。

下面是一個使用props的場景,此時別忘了componentWillReceiveProps 生命周期喲。

參考另一篇文章react的生命周期需要知道的

接上:如果constructor中不通過super來接收props,在其他生命周期,

諸如componentWillMount、componentDidMount、render中能直接使用this.props嗎??

結(jié)論:可以的,react在除了constructor之外的生命周期已經(jīng)傳入了this.props了,完全不受super(props)的影響。

所以super中的props是否接收,只能影響constructor生命周期能否使用this.props,其他的生命周期已默認存在this.props

到此這篇關(guān)于react組件中的constructor和super知識點整理的文章就介紹到這了,更多相關(guān)react組件constructor和super內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React中state屬性和生命周期的使用

    React中state屬性和生命周期的使用

    這篇文章主要介紹了React中state屬性和生命周期的使用說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • React+ResizeObserver實現(xiàn)自適應(yīng)ECharts圖表

    React+ResizeObserver實現(xiàn)自適應(yīng)ECharts圖表

    ResizeObserver是JavaScript的一個API,用于監(jiān)測元素的大小變化,本文主要為大家介紹了React如何利用ResizeObserver實現(xiàn)自適應(yīng)ECharts圖表,需要的可以參考下
    2024-01-01
  • React Native 混合開發(fā)多入口加載方式詳解

    React Native 混合開發(fā)多入口加載方式詳解

    這篇文章主要介紹了React Native 混合開發(fā)多入口加載方式詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2019-09-09
  • React useState超詳細講解用法

    React useState超詳細講解用法

    我正在處理的組件是表單的時間輸入。表單相對復(fù)雜,并且是動態(tài)生成的,根據(jù)嵌套在其他數(shù)據(jù)中的數(shù)據(jù)顯示不同的字段。我正在用useReducer管理表單的狀態(tài),到目前為止效果很好
    2022-11-11
  • 聊聊ant?design?charts?獲取后端接口數(shù)據(jù)展示問題

    聊聊ant?design?charts?獲取后端接口數(shù)據(jù)展示問題

    今天在做項目的時候遇到幾個讓我很頭疼的問題,一個是通過后端接口成功訪問并又返回數(shù)據(jù),但拿不到數(shù)據(jù)值。其二是直接修改state中的data,console中數(shù)組發(fā)生變化但任然數(shù)據(jù)未顯示,這篇文章主要介紹了ant?design?charts?獲取后端接口數(shù)據(jù)展示,需要的朋友可以參考下
    2022-05-05
  • React?Hydrate原理源碼解析

    React?Hydrate原理源碼解析

    這篇文章主要為大家介紹了React?Hydrate原理源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • 詳解如何封裝和使用一個React鑒權(quán)組件

    詳解如何封裝和使用一個React鑒權(quán)組件

    JavaScript?和?React?提供了靈活的事件處理機制,特別是通過利用事件的捕獲階段來阻止事件傳播可以實現(xiàn)精細的權(quán)限控制,本文將詳細介紹這一技術(shù)的應(yīng)用,并通過實踐案例展示如何封裝和使用一個?React?鑒權(quán)組件,需要的可以參考下
    2024-03-03
  • react axios配置代理(proxy),如何解決本地開發(fā)時的跨域問題

    react axios配置代理(proxy),如何解決本地開發(fā)時的跨域問題

    這篇文章主要介紹了react axios配置代理(proxy),如何解決本地開發(fā)時的跨域問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • React通過redux-persist持久化數(shù)據(jù)存儲的方法示例

    React通過redux-persist持久化數(shù)據(jù)存儲的方法示例

    這篇文章主要介紹了React通過redux-persist持久化數(shù)據(jù)存儲的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-02-02
  • React文字展開收起組件的實現(xiàn)示例

    React文字展開收起組件的實現(xiàn)示例

    本文主要介紹了React文字展開收起組件的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2022-07-07

最新評論