React.PureComponent 的簡單理解

對于 React.PureComponent 組件函數(shù)傳遞渲染情況探討

  1. 對于給子組件傳遞函數(shù)的時候, 方式如下

    // Parent.js (class Parent extends React.Component)
    state = { a : 1}
    changeA = ()=> {
      this.setState({a:2});
    }
    handle1() {}
    handle2=()=> {}
    
    render() {
      return (
        <div>
         <button onClick={this.changeA}>Change Parent State</button>
         <PureChildren myfunc={this.handle1} text="handle1 no-arrow" />
         <PureChildren myfunc={() => this.handle1} text="handle1 with-arrow" />
    
         <PureChildren myfunc={this.handle2} text="handle2 no-arrow" />
         <PureChildren myfunc={() => this.handle2} text="handle2 with-arrow" />
        </div>
      );
    }
    
  2. 上述代碼輸出結(jié)果

    // 點擊change parent state按鈕, 修改parent組件的state, 打印結(jié)果如下
    PageA render
    handle1 with-arrow PureChildren Render
    handle2 with-arrow PureChildren Render
    

PureComponent 引用

export default class PageB extends React.PureComponent {
  // 將PureComponebt改成Component看看效果
  state = {
    items: [{ a: 1 }, { a: 2 }, { a: 3 }],
  };
  handleClick = () => {
    const { items } = this.state;
    // items[0].a = 3;
    // items.pop();
    items.splice(items.length - 1, 1);
    this.setState({ items });
    // this.setState({ items: [...items] });
  };
  render() {
    console.log('Parent Rendering', this.state.items);
    return (
      <div>
        <ul>
          {this.state.items.map(i => (
            // <li key={i}>{i}</li>
            <li key={i.a}>{i.a}</li>
          ))}
        </ul>
        {/* <div>{this.state.item[0].a}</div> */}
        <button onClick={this.handleClick}>delete</button>
      </div>
    );
  }
}

點擊上述 delete 按鈕, 發(fā)現(xiàn)節(jié)點 li 并沒有刪除, 這是因為 PureComponent 幫助我們進行了一個簡單的 diff, 發(fā)現(xiàn) nextState.items === prevState.items 為 true, 因為 items 是引用關系, 所以如果在 PureComponent 組件下, 需要重新創(chuàng)建一個新數(shù)組

handleClick = () => {
  const { items } = this.state;
  items.pop();
  this.setState({ items: [...items] });
};

固定空對象

export default class PageC extends React.Component {
  static obj = {};

  state = {
    c: '3',
  };

  handleClick = () => {
    this.setState({
      c: '4',
    });
  };

  render() {
    // const obj = {}; // 對象放在這里, 每一次渲染都是一個新對象, 所以會造成PureComponent 的重新渲染
    return (
      <div>
        <button onClick={this.handleClick}>PageC {this.state.c}</button>
        <PureComponent obj={PageC.obj} />
      </div>
    );
  }
}

點擊 PageC 按鈕的時候, 組件狀態(tài)更新, 如果使用 render 中定義的 obj, 每次傳遞給 PureComponent 組件的屬性 obj 都是一個新的對象, 所以會造成 PureComponent 的 re-render

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市记劈,隨后出現(xiàn)的幾起案子番川,更是在濱河造成了極大的恐慌算途,老刑警劉巖呼巴,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異顶瞳,居然都是意外死亡独令,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門社付,熙熙樓的掌柜王于貴愁眉苦臉地迎上來承疲,“玉大人,你說我怎么就攤上這事鸥咖⊙喔耄” “怎么了?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵啼辣,是天一觀的道長啊研。 經(jīng)常有香客問我,道長鸥拧,這世上最難降的妖魔是什么党远? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮住涉,結(jié)果婚禮上麸锉,老公的妹妹穿的比我還像新娘。我一直安慰自己舆声,他們只是感情好花沉,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著媳握,像睡著了一般碱屁。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蛾找,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天娩脾,我揣著相機與錄音,去河邊找鬼打毛。 笑死柿赊,一個胖子當著我的面吹牛俩功,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播碰声,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼诡蜓,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了胰挑?” 一聲冷哼從身側(cè)響起蔓罚,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎瞻颂,沒想到半個月后豺谈,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡贡这,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年茬末,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片藕坯。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡团南,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出炼彪,到底是詐尸還是另有隱情,我是刑警寧澤正歼,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布辐马,位于F島的核電站,受9級特大地震影響局义,放射性物質(zhì)發(fā)生泄漏喜爷。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一萄唇、第九天 我趴在偏房一處隱蔽的房頂上張望檩帐。 院中可真熱鬧,春花似錦另萤、人聲如沸湃密。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽泛源。三九已至,卻和暖如春忿危,著一層夾襖步出監(jiān)牢的瞬間达箍,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工铺厨, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留缎玫,地道東北人硬纤。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像赃磨,于是被迫代替她去往敵國和親咬摇。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

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