首頁 > web前端 > js教程 > react元件有過哪些效能優化

react元件有過哪些效能優化

coldplay.xixi
發布: 2020-11-19 17:55:29
原創
2987 人瀏覽過

react的元件效能最佳化有:1、盡量多使用無狀態函數建置元件;2、分割元件為子元件,對元件做更細緻的控制;3、運用PureRender,對變更做出最少的渲染;4、運用immutable。

react元件有過哪些效能優化

react的元件效能最佳化有:

1. 盡量多使用無狀態函數建構元件

無狀態元件只有props和context兩個參數。它不存在state,沒有生命週期方法,元件本身就是有狀態元件建構方法中的render方法。

在適當的情況下,都應該必須使用無狀態元件。無狀態元件不會像React.createClass和ES6 class會在呼叫時建立新實例,它在建立時始終保持了一個實例,避免了不必要的檢查和記憶體分配,做到了內部最佳化。

2. 分割元件為子元件,對元件做更細緻的控制

相關重要概念: 純函數

純函數的三大構成原則:

給定相同的輸入,它總是回傳相同的輸出: 例如反例有Math.random(), New Date()

##過程沒有副作用:即不能改變外在狀態

沒有額外的狀態依賴:即方法內部的狀態都只能在方法的生命週期內存活,這表示不能在方法內使用共享的變數。

純函數非常方便進行方法層級的測試及重構,它可以讓程式具有良好的擴展性和適應性。純函數是函數式變成的基礎。

React元件本身就是純函數,也就是傳入指定props得到一定的Virtual DOM,整個過程都是可預測的。

具體辦法

分割元件為子元件,對元件做更細緻的控制。保持純淨狀態,可以讓方法或組件更加專注(focus),體積更小(small),更獨立(independent),更具有復用性(reusability)和可測試性(testability)。

3. 運用PureRender,對變更做出最少的渲染

#相關重要概念:

PureRender

PureRender的Pure即是指滿足純函數的條件,也就是元件被相同的props和state渲染會得到相同的結果。

在React中實作PureRender需要重新實作shouldComponentUpdate生命週期方法。 shouldComponentUpdate是一個特別的方法,它接收需要更新的props和state,本質是用來進行正確的元件渲染。當其傳回false的時候,不再向下執行生命週期方法;當其傳回true時,繼續向下執行。

元件會在初始化過程中渲染一個樹狀結構,當父節點props改變的時候,在理想情況下只需渲染一條鏈路上有關props改變的節點;但是,在預設情況下shouldComponentUpdate方法回傳true,React會重新渲染所有的節點。

有一些官方外掛程式實現了對

shouldComponentUpdate的重寫,然後自己也可以做一些程式碼的最佳化來運用PureRender。

具體辦法

(1) 運用

PureRender

使用官方外掛程式react-addons-pure-render-mixin實作對

shouldComponentUpdate的重寫

import React from 'react';
import PureRenderMixin from 'react-addons-pure-render-mixin';
class App extends React.Component {
  constructor(props) {
    super(props);
    this.shouldComponentUpdate = PureRenderMixin.shouldComponentUpdate.bind(this);
  }
  render() {
    return <div className={this.props.className}>foo</div>
  }
}
登入後複製

它的原理是對object(包括props和state)做淺比較,即引用比較,非值比較。例如只用關注props中每一個是否全等(如果是prop是一個物件那就是只比較了地址,地址一樣就算是一樣了),而不用深入比較。

(2)最佳化

PureRender

避免無論如何都會觸發

shouldComponentUpdate傳回true的程式碼寫法。

避免直接為prop設定字面量的陣列和物件

就算每次傳入的陣列或物件的值沒有變,但它們的位址也發生了變化。

如以下寫法每次渲染時style都是新物件都會觸發shouldComponentUpdate為true:

<Account style={{color: &#39;black&#39;}} />
登入後複製

改進方法:將字面量設為一個引用:

const defaultStyle = {};
<Account style={this.props.style || defaultStyle} />
登入後複製

避免每次綁定事件

如果這樣綁定事件的話每次都要產生一個新的

onChange屬性的值:

render() {
  return <input onChange={this.handleChange.bind(this)} />
}
登入後複製

應該盡量在建構子內進行綁定,如果綁定需要傳參那麼應該考慮抽象子元件或改變現有資料結構:

constructor(props) {
  super(props);
  this.handleChange = this.handleChange.bind(this);
}
handleChange() {
  ...
}
render() {
  return <input onChange={this.handleChange} />
}
登入後複製

在設定子元件的時候要在父元件層級重寫

shouldComponentUpdate

4.運用immutable

JavaScript中物件一般是可變的,因為使用引用賦值,新的物件的改變將影響原始物件。為了解決這個問題是使用深拷貝或淺拷貝,但這樣做又造成了CPU和記憶體的浪費。

Immutable data很好地解決了這個問題。

Immutable data就是一旦創建,就不能再更改的資料。對Immutable物件進行修改、新增或刪除操作,都會傳回一個新的Immutable物件。 Immutable實作的原理是持久化的資料結構。即使用舊資料建立新資料時,確保新舊資料同時可用且不變。同時為了避免深拷貝帶來的效能損耗,Immutable使用了結構共享(structural sharing),即如果物件樹中一個節點發生變化,只修改這個節點和受它影響的父節點,其他節點則進行共享。

相關學習推薦:javascript學習教學

以上是react元件有過哪些效能優化的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板