react組件中的constructor和super知識點整理
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+ResizeObserver實現(xiàn)自適應(yīng)ECharts圖表
ResizeObserver是JavaScript的一個API,用于監(jiān)測元素的大小變化,本文主要為大家介紹了React如何利用ResizeObserver實現(xiàn)自適應(yīng)ECharts圖表,需要的可以參考下2024-01-01React Native 混合開發(fā)多入口加載方式詳解
這篇文章主要介紹了React Native 混合開發(fā)多入口加載方式詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2019-09-09聊聊ant?design?charts?獲取后端接口數(shù)據(jù)展示問題
今天在做項目的時候遇到幾個讓我很頭疼的問題,一個是通過后端接口成功訪問并又返回數(shù)據(jù),但拿不到數(shù)據(jù)值。其二是直接修改state中的data,console中數(shù)組發(fā)生變化但任然數(shù)據(jù)未顯示,這篇文章主要介紹了ant?design?charts?獲取后端接口數(shù)據(jù)展示,需要的朋友可以參考下2022-05-05react axios配置代理(proxy),如何解決本地開發(fā)時的跨域問題
這篇文章主要介紹了react axios配置代理(proxy),如何解決本地開發(fā)時的跨域問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07React通過redux-persist持久化數(shù)據(jù)存儲的方法示例
這篇文章主要介紹了React通過redux-persist持久化數(shù)據(jù)存儲的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02