關於React效能最佳化

來源:互聯網
上載者:User

標籤:entry   list   ref   關於   air   提高   false   next   react   

這幾天陸陸續續看了一些關於React效能最佳化的部落格,大部分提到的都是React 15.3新加入的PureComponent ,通過使用這個類來減少React的重複渲染,從而提升頁面的效能。使用過React的朋友都知道,React組件只有在state和props發生改變時才會觸發render,如果state和props沒有發生改變,render就不執行。通常在寫頁面的時候,如果沒有使用PureComponent類,為了避免重複渲染而產生的效能問題,我們會使用shouldComponentUpdate手動來比較頁面是否需要重新渲染,這時我們是可以進行深比較的,也就是將當前的state與nextState或者props與nextProps一層一層進行比較,如果比較發現不相等,這個函數就返回true從而使組件重新渲染,如果比較後發現值沒有改變則返回false來阻止組件重新渲染。當我們使用了PureComponent類後,就不再需要手動檢查組件是否需要重新渲染了,因為PureComponent會幫我們檢查state和prop是否發生改變,從而決定是否要調用render方法,從而提高效能。但是需要注意的是,使用PureComponent時,React只是做了最外層的淺比較:

if (this._compositeType === CompositeTypes.PureClass) {
shouldUpdate = !shallowEqual(prevProps, nextProps) || ! shallowEqual(inst.state, nextState);
}
shadowEqual只會淺檢查組件的props和state,所以嵌套對象和數組是不會被比較的。所以使用了PureComponent的時候,我們要特別注意這一點。

好了,今天要分享的除了上面的關於PureComponent的原理外,還要分享一篇關於React效能最佳化的乾貨部落格,

英文原文: React Performance Fixes on Airbnb Listing Pages:https://medium.com/airbnb-engineering/recent-web-performance-fixes-on-airbnb-listing-pages-6cd8d93df6f4

譯文:Airbnb 愛彼迎房源詳情頁中的 React 效能最佳化:https://juejin.im/entry/5bab390c5188255c8a06013f

轉載地址:https://www.f2ecoder.net/857.html

關於React效能最佳化

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.