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

Component與PureComponent對(duì)比解析

 更新時(shí)間:2023年03月01日 12:01:33   作者:別哭0摸摸頭  
這篇文章主要為大家介紹了Component與PureComponent解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

題外話

有啥不對(duì)的請(qǐng)多多指教,研究的不算很深,記錄為了分享,也為了博采眾長(zhǎng),完善知識(shí)。

官方文檔

React.PureComponent 與 React.Component很相似。兩者的區(qū)別在于 React.Component 并未實(shí)現(xiàn) shouldComponentUpdate(),而 React.PureComponent 中以淺層對(duì)比 prop 和 state 的方式來實(shí)現(xiàn)了該函數(shù)。

官方解釋也很容易理解,React.PureComponentReact.Component中多實(shí)現(xiàn)了一個(gè)方法,就導(dǎo)致了在組件數(shù)據(jù)發(fā)生變化時(shí),React.PureComponent會(huì)先進(jìn)行和上一次的比較,如果相同,就不會(huì)再繼續(xù)更新了。

口說無憑,還是得通過代碼來體會(huì)。

對(duì)比

先看兩者相同得地方 代碼如下

class Box1 extends React.Component {
  render() {
    console.log('Box1 update');
    return <div>Box1: {this.props.count}</div>;
  }
}
class Box2 extends React.PureComponent {
  render() {
    console.log('Box2 update');
    return <div>Box2: {this.props.count}</div>;
  }
}

先制作2個(gè)對(duì)比的組件Box1與Box2, 然后制作一個(gè)父組件引入其中,并設(shè)置一個(gè)方法

export default () => {
  const [count, setCount] = React.useState(1);
  console.log('parent update');
  return (
    <div>
      <Box1 count={count}/>
      <Box2 count={count}/>
      <button onClick={() => setCount(count + 1)}>+1</button>
    </div>
  );
};

此時(shí),點(diǎn)擊button按鈕的時(shí)候,上述2個(gè)Box組件都會(huì)進(jìn)行更新。

這也是最基礎(chǔ)的組件更新。

取消外部數(shù)據(jù)引入

class Box1 extends React.Component {
  render() {
    console.log('Box1 update');
    return <div>Box1</div>;
  }
}
class Box2 extends React.PureComponent {
  render() {
    console.log('Box2 update');
    return <div>Box2</div>;
  }
}
export default () => {
  const [count, setCount] = React.useState(1);
  console.log('parent update');
  return (
    <div>
      <Box1 />
      <Box2 />
      <button onClick={() => setCount(count + 1)}>+1</button>
    </div>
  );
};

取消Box組件內(nèi)對(duì)外部count的引入

此時(shí)頁面更新為

此時(shí)會(huì)發(fā)現(xiàn)只有Box1重新刷新了一遍,而Box2未重新加載組件,也就是PureComponent內(nèi)部做了淺比較相同的不會(huì)進(jìn)行更新。

為什么被稱為淺比較

淺比較是指對(duì)值類型進(jìn)行比較,而稍微復(fù)雜一點(diǎn)的引用類型(Object),就無法進(jìn)行判斷了,react內(nèi)部的更新都是淺比較。

export default () => {
  const [count, setCount] = React.useState({ num: 1 });
  console.log('parent update');
  const click = () => {
    const newCount = count;
    newCount.num = count.num + 1;
    setCount(newCount);
    console.log('update:', count)
  };
  return (
    <div>
      <Box1 />
      <Box2 />
      <button onClick={click}>+1</button>
    </div>
  );
};

此時(shí),父組件內(nèi)部的count為對(duì)象類型,此時(shí)進(jìn)行更新時(shí),頁面不會(huì)觸發(fā)任何更新,父組件也不會(huì)進(jìn)行刷新(由于是引用類型,newCount發(fā)生數(shù)據(jù)變化時(shí),count其實(shí)已經(jīng)發(fā)生變化,但是頁面并不會(huì)有任何的反應(yīng))。

由圖可見,子組件和父組件并沒有進(jìn)行刷新,均未打印。

小知識(shí)點(diǎn)

const的不可變定義也是只對(duì)于值類型而言,對(duì)于引用類型,還是依然可變。上述代碼云清并不會(huì)報(bào)錯(cuò)。

說明

上述的一切代碼都是建立在父組件自身更新的基礎(chǔ)上子組件才會(huì)刷新,如果我將setCount(count + 1)改為setCount(count + 0),那么,父組件本身不會(huì)進(jìn)行刷新,子組件也就理所當(dāng)然的不會(huì)有任何變化。

另類的不更新

這里的父組件刷新帶動(dòng)子組件刷新有一種例外的情況。代碼如下

const Parent = ({ children }) => {
  const [count, setCount] = React.useState(1);

  console.log('parent update');
  return (
    <div>
      {children}
      <button onClick={() => setCount(count + 1)}>box2</button>
    </div>
  );
};

export default () => {
  return (
    <Parent>
      <Box1 />
      <Box2 />
    </Parent>
  );
};

將父組件抽離出來,子組件以children的形式引入。 此時(shí)頁面點(diǎn)擊發(fā)生的變化為

會(huì)發(fā)現(xiàn)不管怎么點(diǎn)擊,只有Parent組件進(jìn)行刷新,子組件全部都毫無反應(yīng)。

這個(gè)原因我不得而知,可能是因?yàn)閞eact生成dom的時(shí)候問題,這個(gè)等待深入學(xué)習(xí)后再來解答。

總結(jié)

PureComponent多用于抽取本地緩存制作的下拉框組件或者是根據(jù)數(shù)據(jù)字典生成的展示組件,這種固定的組件基本在用戶使用時(shí)不會(huì)有任何的變化,只在登錄和頁面加載最開始生成。

以上就是Component與PureComponent解析的詳細(xì)內(nèi)容,更多關(guān)于Component PureComponent解析的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • React Hooks常用場(chǎng)景的使用(小結(jié))

    React Hooks常用場(chǎng)景的使用(小結(jié))

    這篇文章主要介紹了React Hooks常用場(chǎng)景的使用,根據(jù)使用場(chǎng)景分別進(jìn)行舉例說明,幫助你認(rèn)識(shí)理解并可以熟練運(yùn)用 React Hooks 大部分特性,感興趣的可以了解一下
    2021-04-04
  • React18從0實(shí)現(xiàn)dispatch?update流程

    React18從0實(shí)現(xiàn)dispatch?update流程

    這篇文章主要為大家介紹了React18從0實(shí)現(xiàn)dispatch?update流程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • 原生實(shí)現(xiàn)一個(gè)react-redux的代碼示例

    原生實(shí)現(xiàn)一個(gè)react-redux的代碼示例

    這篇文章主要介紹了原生實(shí)現(xiàn)一個(gè)react-redux的代碼示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • 基于Webpack5 Module Federation的業(yè)務(wù)解耦實(shí)踐示例

    基于Webpack5 Module Federation的業(yè)務(wù)解耦實(shí)踐示例

    這篇文章主要為大家介紹了基于Webpack5 Module Federation的業(yè)務(wù)解耦實(shí)踐示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • React+Node實(shí)現(xiàn)大文件分片上傳、斷點(diǎn)續(xù)傳秒傳思路

    React+Node實(shí)現(xiàn)大文件分片上傳、斷點(diǎn)續(xù)傳秒傳思路

    本文主要介紹了React+Node實(shí)現(xiàn)大文件分片上傳、斷點(diǎn)續(xù)傳秒傳思路,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • React組件的生命周期深入理解分析

    React組件的生命周期深入理解分析

    組件的生命周期就是React的工作過程,就好比人有生老病死,自然界有日月更替,每個(gè)組件在網(wǎng)頁中也會(huì)有被創(chuàng)建、更新和刪除,如同有生命的機(jī)體一樣
    2022-12-12
  • React RenderProps模式超詳細(xì)講解

    React RenderProps模式超詳細(xì)講解

    render props是指一種在 React 組件之間使用一個(gè)值為函數(shù)的 prop 共享代碼的技術(shù)。簡(jiǎn)單來說,給一個(gè)組件傳入一個(gè)prop,這個(gè)props是一個(gè)函數(shù),函數(shù)的作用是用來告訴這個(gè)組件需要渲染什么內(nèi)容,那么這個(gè)prop就成為render prop
    2022-11-11
  • ReactJs快速入門教程(精華版)

    ReactJs快速入門教程(精華版)

    React 起源于 Facebook 的內(nèi)部項(xiàng)目,因?yàn)樵摴緦?duì)市場(chǎng)上所有 JavaScript MVC 框架,都不滿意,就決定自己寫一套,用來架設(shè) Instagram 的網(wǎng)站.這篇文章主要介紹了ReactJs快速入門教程(精華版)的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • 一文詳解如何使用React監(jiān)聽網(wǎng)絡(luò)狀態(tài)

    一文詳解如何使用React監(jiān)聽網(wǎng)絡(luò)狀態(tài)

    在現(xiàn)代Web應(yīng)用程序中,網(wǎng)絡(luò)連接是至關(guān)重要的,通過監(jiān)聽網(wǎng)絡(luò)狀態(tài),我們可以為用戶提供更好的體驗(yàn),例如在斷網(wǎng)時(shí)顯示有關(guān)網(wǎng)絡(luò)狀態(tài)的信息,本文將介紹如何使用React監(jiān)聽網(wǎng)絡(luò)狀態(tài)的變化,并提供相應(yīng)的代碼示例
    2023-06-06
  • React Electron生成桌面應(yīng)用過程

    React Electron生成桌面應(yīng)用過程

    這篇文章主要介紹了React+Electron快速創(chuàng)建并打包成桌面應(yīng)用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12

最新評(píng)論