React的生命周期

中文文檔:State&生命周期-React
英文文檔:StateandLifecycle–React

簡單來說碑宴,一個組件的生命周期可以分為四個部分:

  1. 創(chuàng)造 - 生
  2. 掛載到頁面
  3. 更新
  4. 毀滅 - 死

用js來寫個簡單的例子

let app = document.getElementById('app');

//create div
let div = document.createElement('div');
div.style.border = '1px solid red';

let state = 0;
div.innerHTML = `
    <p>${state}</p>
    <button>+1</button>
    <button>die</button>
`;

//mount div
app.appendChild(div);

div.querySelector('button').onClick = () => {
    state += 1;
    //update div
    div.querySelector('p').innerText = state;
};

div.querySelectorAll('button')[1].onClick = () => {
    //清理事件監(jiān)聽
    div.querySelector('button').onClick = null;
    div.querySelectorAll('button')[1].onClick = null;
    div.remove();
    //destroy div
    div = null;  
};

再來看看React的生命周期



值得注意的是软啼,函數(shù)是沒有生命周期的,只有class組件有

來看看React的生命周期里有哪些鉤子

import React from "react";
import ReactDOM from "react-dom";
import "./styles.css";

let div = document.createElement("div");
document.body.appendChild(div);
console.log = function(content) {
  div.innerHTML += `${content}<br>`;
};

class Baba extends React.Component {
  constructor() {
    super();
    this.state = {
      hasChild: true
    };
  }
  onClick() {
    this.setState({
      hasChild: false
    });
  }
  callSon() {
    this.setState({
      word: "你還好吧"
    });
  }
  render() {
    return (
      <div>
        我是你爸爸
        <button onClick={() => this.onClick()}>kill son</button>
        <button onClick={() => this.callSon()}>call son</button>
        {this.state.hasChild ? <App word={this.state.word} /> : null}
      </div>
    );
  }
}

class App extends React.Component {
  onClick() {
    console.log("用戶點擊了");
    this.setState({
      n: this.state.n + 1
    });
  }
  updateX() {
    this.setState({
      x: this.state.x + "!"
    });
  }
  constructor() {
    super();
    this.state = {
      n: 0,
      x: "不展示"
    };
  }
  componentWillMount() {
    console.log("將要 mount App");
  }
  render() {
    // update
    console.log("填充/更新 App 的內(nèi)容");
    return (
      <div className="App">
        {this.state.n}
        <br />
        我爸說 {this.props.word}
        <br />
        <button onClick={() => this.onClick()}>+1</button>
        <button onClick={() => this.updateX()}>update x</button>
      </div>
    );
  }
  componentDidMount() {
    console.log("mount App 完畢");
  }
  componentWillUpdate() {
    console.log("update App 之前");
  }
  shouldComponentUpdate(nextProps, nextState) {
    console.log("要不要更新呢延柠?");
    if (this.state.n === nextState.n) {
      console.log('不更新')
      return false;
    } else {
      console.log('更新')
      return true;
    }
  }
  //update is render
  componentDidUpdate() {
    console.log("update App 之后");
  }
  componentWillUnmount() {
    console.log("App 快要死了祸挪,記得喂狗");
  }
  componentWillReceiveProps() {
    console.log("我爸說話了");
  }
}

const rootElement = document.getElementById("root");
ReactDOM.render(<Baba />, rootElement);

關于React生命周期的幾道面試題

生命周期的哪個階段異步請求數(shù)據(jù)?

componentDidMount
最主要的原因是:

  1. 在componentWillUnMount中無法確保在執(zhí)行render前已經(jīng)獲得了異步請求的數(shù)據(jù)贞间,componentDidMount不存在這個問題贿条;
  2. 為了性能的需要,React下一代tiao'he
  3. 無法保證ajax請求在組件的更新階段里成功返回數(shù)據(jù)榜跌,有可能當我們進行setState處理的時候闪唆,組件已經(jīng)被銷毀了。

請說出所有的生命周期鉤子

  1. constructor()
  2. componentWillMount() // 將要Mount
  3. render() // 填充/更新
  4. componentDidMount() // Mount 完畢
  5. componentWillUpdate // 更新之前
  6. componentDidUpdate // 更新之后
  7. componentWillUnmount() // 組件被銷毀之前钓葫,只能由父組件銷毀子組件
  8. componentWillReceiveProps() // 父組件向子組件傳值了
  9. shouldComponentUpdate() //是否要更新
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末悄蕾,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子础浮,更是在濱河造成了極大的恐慌帆调,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件豆同,死亡現(xiàn)場離奇詭異番刊,居然都是意外死亡,警方通過查閱死者的電腦和手機影锈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門芹务,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人鸭廷,你說我怎么就攤上這事枣抱。” “怎么了辆床?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵佳晶,是天一觀的道長。 經(jīng)常有香客問我讼载,道長轿秧,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任咨堤,我火速辦了婚禮菇篡,結果婚禮上,老公的妹妹穿的比我還像新娘吱型。我一直安慰自己逸贾,他們只是感情好,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布津滞。 她就那樣靜靜地躺著铝侵,像睡著了一般。 火紅的嫁衣襯著肌膚如雪触徐。 梳的紋絲不亂的頭發(fā)上咪鲜,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天,我揣著相機與錄音撞鹉,去河邊找鬼疟丙。 笑死,一個胖子當著我的面吹牛鸟雏,可吹牛的內(nèi)容都是我干的享郊。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼孝鹊,長吁一口氣:“原來是場噩夢啊……” “哼炊琉!你這毒婦竟也來了?” 一聲冷哼從身側響起又活,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤苔咪,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后柳骄,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體团赏,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年耐薯,在試婚紗的時候發(fā)現(xiàn)自己被綠了舔清。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡曲初,死狀恐怖体谒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情复斥,我是刑警寧澤营密,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站目锭,受9級特大地震影響评汰,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜痢虹,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一被去、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧奖唯,春花似錦惨缆、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽寂汇。三九已至,卻和暖如春捣染,著一層夾襖步出監(jiān)牢的瞬間骄瓣,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工耍攘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留榕栏,地道東北人。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓蕾各,卻偏偏與公主長得像扒磁,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子式曲,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353

推薦閱讀更多精彩內(nèi)容