4.react生命周期

面試題

1霹菊、React中的生命周期有哪些剧蚣?

constructor
componentWillMount
render
componentDidMount
componentWillReceiveProps
shouldComponentUpdate
componentWillUpdate
componentDidUpdate
componentWillUnmount

2、React中組件第一次執(zhí)行的時(shí)候會(huì)執(zhí)行哪些生命周期函數(shù)

constructor
componentWillMount
render
componentDidMount

3旋廷、render函數(shù)什么時(shí)候會(huì)執(zhí)行鸠按?

當(dāng)this.state/this.props發(fā)生改變的時(shí)候

4、當(dāng)this.props/this.state發(fā)生改變的時(shí)候會(huì)執(zhí)行哪些生命周期

this.props
  componentWillReceiveProps
  shouldComponentUpdate
  componentWillUpdate
  render
  componentDidUpdate

this.state
   shouldComponentUpdate
   componentWillUpdate
   render
   componentDidUpdate

5饶碘、React中哪些生命周期會(huì)執(zhí)行一次目尖,哪些生命周期會(huì)執(zhí)行多次

多次
    componentWillReceiveProps
    shouldComponentUpdate
    componentWillUpdate
    render
    componentDidUpdate
一次
   constructor
   componentWillMount
   componentDidMount
   componentWillUnmount
1、constructor:

1扎运、組件的初始化瑟曲,用來(lái)定義當(dāng)前組件所需要的一些狀態(tài),狀態(tài)定義在this.state中豪治。
2洞拨、當(dāng)前生命周期中必須書寫super,否則this的指向會(huì)發(fā)生錯(cuò)誤以及報(bào)錯(cuò)
3鬼吵、在當(dāng)前生命周期中默認(rèn)是訪問(wèn)不到props屬性的,如果想要進(jìn)行訪問(wèn)必須在super以及constructor中添加參數(shù)props

2篮赢、componentWillMount:

掛載前:
1齿椅、可以進(jìn)行前后端數(shù)據(jù)的請(qǐng)求(在服務(wù)端渲染的時(shí)候)
2、可以在數(shù)據(jù)第一次被渲染的時(shí)候做數(shù)據(jù)的更改
3启泣、在當(dāng)前生命周期中盡量不要調(diào)用this.setState因?yàn)楫?dāng)前生命周期函數(shù)執(zhí)行完畢后涣脚,會(huì)自動(dòng)執(zhí)行render函數(shù)
4、可以將外部的數(shù)據(jù)轉(zhuǎn)換為內(nèi)部的數(shù)據(jù)

注意:當(dāng)前生命周期在17.0中已經(jīng)廢除掉了

3寥茫、render:

1遣蚀、當(dāng)前生命周期用來(lái)進(jìn)行數(shù)據(jù)與模板的結(jié)合
2、render函數(shù)第一次執(zhí)行的時(shí)候會(huì)將渲染的數(shù)據(jù)在內(nèi)存中保存一份,當(dāng)?shù)诙螖?shù)據(jù)發(fā)生了改變后芭梯,render會(huì)將這次的虛擬DOM與緩存中的虛擬DOM進(jìn)行對(duì)比 這種對(duì)比叫做DIFF算法
3险耀、只要this.state/this.props發(fā)生了改變那么render函數(shù)就會(huì)執(zhí)行

4、componentDidMount:

掛載后:
1玖喘、當(dāng)前生命周期我們可以做前后端數(shù)據(jù)的交互
2甩牺、可以在當(dāng)前生命周期中獲取到真實(shí)的DOM 通過(guò)this.refs來(lái)獲取
3、一般情況下我們都在當(dāng)前生命周期中做一些插件的實(shí)例化new Swiper('')

操作真實(shí)DOM的方式
ref="h2" this.refs.h2
ref={(el)=>{this.dom = el}} this.dom

5累奈、 componentWillReceiveProps

1贬派、當(dāng)this.props發(fā)生改變的時(shí)候當(dāng)前函數(shù)就會(huì)執(zhí)行
2、當(dāng)前函數(shù)中會(huì)有一個(gè)參數(shù) 這個(gè)參數(shù)是一個(gè)新的props
3澎媒、在當(dāng)前生命周期函數(shù)中我們可以對(duì)新的props做修改

注意:當(dāng)前生命周期函數(shù)在17.0中廢除掉了

6搞乏、shouldComponentUpdate

1、當(dāng)this.state/this.props被修改的時(shí)候會(huì)執(zhí)行當(dāng)前生命周期函數(shù)
2戒努、當(dāng)前生命周期執(zhí)行的時(shí)候必須返回一個(gè)true或者是false 返回值決定了render函數(shù)是否會(huì)執(zhí)行请敦,如果為true則render函數(shù)執(zhí)行,false則render函數(shù)不會(huì)執(zhí)行
3柏卤、如果返回值為true則下面的生命周期會(huì)執(zhí)行冬三,如果為false則下面的生命周期不會(huì)執(zhí)行
4、當(dāng)前生命周期特別重要缘缚,因?yàn)楫?dāng)前生命可以做React的性能優(yōu)化,(根據(jù)比較新舊的state/props來(lái)進(jìn)行對(duì)比)
5勾笆、當(dāng)前生命周期函數(shù)中有2個(gè)參數(shù)一個(gè)是新的props 一個(gè)是新的state

shouldComponentUpdate(newProps,newState) {
        console.log("shouldComponentUpdate")

        // if(this.state.message == newState.message){
        //     return false;
        // }else{
        //     return true;
        // }
        return true;
    }

6、當(dāng)期生命周期決定的是render函數(shù)是否執(zhí)行桥滨,而不是數(shù)據(jù)是否修改

7窝爪、 componentWillUpdate

更新前:
1、在當(dāng)前生命周期中我們可以對(duì)更新的數(shù)據(jù)做最后的修改
2齐媒、當(dāng)前生命周期中有2個(gè)參數(shù) 一個(gè)是新的props一個(gè)是新的state

8蒲每、 componentDidUpdate:

更新后
1、當(dāng)前生命周期中我們可以獲取到數(shù)據(jù)更新后最新的DOM結(jié)構(gòu)
2喻括、注意當(dāng)前生命周期會(huì)執(zhí)行多次邀杏,所以當(dāng)你需要做業(yè)務(wù)邏輯操作的時(shí)候一定要判斷

9、 componentWillUnmount:

卸載
1唬血、當(dāng)前生命周期執(zhí)行的時(shí)候我們需要做事件的解綁
2望蜡、數(shù)據(jù)的移除等操作

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市拷恨,隨后出現(xiàn)的幾起案子脖律,更是在濱河造成了極大的恐慌,老刑警劉巖腕侄,帶你破解...
    沈念sama閱讀 211,376評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件小泉,死亡現(xiàn)場(chǎng)離奇詭異芦疏,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)微姊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門酸茴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人柒桑,你說(shuō)我怎么就攤上這事弊决。” “怎么了魁淳?”我有些...
    開(kāi)封第一講書人閱讀 156,966評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵飘诗,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么娱挨? 我笑而不...
    開(kāi)封第一講書人閱讀 56,432評(píng)論 1 283
  • 正文 為了忘掉前任掘猿,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好喳瓣,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著赞别,像睡著了一般畏陕。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上仿滔,一...
    開(kāi)封第一講書人閱讀 49,792評(píng)論 1 290
  • 那天惠毁,我揣著相機(jī)與錄音,去河邊找鬼崎页。 笑死鞠绰,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的飒焦。 我是一名探鬼主播蜈膨,決...
    沈念sama閱讀 38,933評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼牺荠!你這毒婦竟也來(lái)了翁巍?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 37,701評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤志电,失蹤者是張志新(化名)和其女友劉穎曙咽,沒(méi)想到半個(gè)月后蛔趴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體挑辆,經(jīng)...
    沈念sama閱讀 44,143評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡例朱,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鱼蝉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片洒嗤。...
    茶點(diǎn)故事閱讀 38,626評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖魁亦,靈堂內(nèi)的尸體忽然破棺而出渔隶,到底是詐尸還是另有隱情,我是刑警寧澤洁奈,帶...
    沈念sama閱讀 34,292評(píng)論 4 329
  • 正文 年R本政府宣布间唉,位于F島的核電站,受9級(jí)特大地震影響利术,放射性物質(zhì)發(fā)生泄漏呈野。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評(píng)論 3 313
  • 文/蒙蒙 一印叁、第九天 我趴在偏房一處隱蔽的房頂上張望被冒。 院中可真熱鬧,春花似錦轮蜕、人聲如沸昨悼。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,742評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)率触。三九已至,卻和暖如春税课,著一層夾襖步出監(jiān)牢的瞬間闲延,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工韩玩, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留垒玲,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓找颓,卻偏偏與公主長(zhǎng)得像合愈,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子击狮,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評(píng)論 2 348