React如何避免重渲染-創(chuàng)新互聯(lián)

組件的重新渲染

創(chuàng)新互聯(lián)擁有網站維護技術和項目管理團隊,建立的售前、實施和售后服務體系,為客戶提供定制化的網站制作、網站設計、網站維護、大邑服務器托管解決方案。為客戶網站安全和日常運維提供整體管家式外包優(yōu)質服務。我們的網站維護服務覆蓋集團企業(yè)、上市公司、外企網站、成都做商城網站、政府網站等各類型客戶群體,為全球上1000+企業(yè)提供全方位網站維護、服務器維護解決方案。

我們可以在 React 組件中的 props 和 state 存放任何類型的數據,通過改變 props 和 state,去控制整個組件的狀態(tài)。當 props 和 state 發(fā)生變化時,React 會重新渲染整個組件,組件重新渲染的過程可簡化如下圖:

React如何避免重渲染

譯者之前對diff的理解是,對于一個改變 props 的組件,diff能自動計算出組件內部DOM樹的不同,然后經過對比,找出真正變化的DOM節(jié)點,對變化部分進行渲染。這個是錯誤的理解,diff算法只是用來計算出改變狀態(tài)或 props的組件/虛擬節(jié)點,而這個組件/虛擬節(jié)點,無論多大,它都會重新渲染。

假設有一個渲染完成的組件,如下圖:

React如何避免重渲染

接下來因為狀態(tài)改變,需要重新渲染下圖的綠色的節(jié)點,如下圖:

React如何避免重渲染

一般的想法是只需要更新下面的三個綠色節(jié)點就能夠完成組件的更新

React如何避免重渲染

然而!只要組件的 props 或 state 發(fā)生了變化就會重新渲染整個組件,因此除了上述的三個綠色節(jié)點以外,還需要重新渲染所有的黃色的節(jié)點

React如何避免重渲染

除了必要渲染的三個節(jié)點外,還渲染了其他不必要渲染的節(jié)點,這對性能是一個很大的浪費。如果對于復雜的頁面,這將導致頁面的整體體驗效果非常差。因此要提高組件的性能,就應該想盡一切方法減少不必要的渲染。

shouldComponentUpdate

shouldComponentUpdate這個函數會在組件重新渲染之前調用,函數的返回值確定了組件是否需要重新渲染。函數默認的返回值是 true,意思就是只要組件的 props 或者 state 發(fā)生了變化,就會重新構建 virtual DOM,然后使用 diff 算法進行比較,再接著根據比較結果決定是否重新渲染整個組件。函數的返回值為 false 表示不需要重新渲染。

函數默認返回為 true.

PureRenderMixin

React 官方提供了 PureRenderMixin 插件,插件的功能就是在不必要的情況下讓函數 shouldComponentUpdate 返回 false, 使用這個插件就能夠減少不必要的重新渲染,得到一定程度上的性能提升,其使用方法如下:

  import PureRenderMixin from 'react-addons-pure-render-mixin';
  class FooComponent extends React.Component {
   constructor(props) {
    super(props);
    this.shouldComponentUpdate = PureRenderMixin.shouldComponentUpdate.bind(this);
   }

   render() {
    return <div className={this.props.className}>foo</div>;
   }
  }

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

網站名稱:React如何避免重渲染-創(chuàng)新互聯(lián)
文章網址:http://bm7419.com/article48/ggihp.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)網站制作、手機網站建設、企業(yè)建站、外貿網站建設商城網站、網站建設

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

h5響應式網站建設