日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

reactjs组件优化:setState的反复render问题

發布時間:2025/1/21 编程问答 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 reactjs组件优化:setState的反复render问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

組件優化

Component的2個問題

  • 只要執行setState(),即使不改變狀態數據, 組件也會重新render() ==> 效率低

  • 只當前組件重新render(), 就會自動重新render子組件,縱使子組件沒有用到父組件的任何數據 ==> 效率低

  • 效率高的做法

    只有當組件的state或props數據發生改變時才重新render()

    原因

    Component中的shouldComponentUpdate()總是返回true

    解決

    辦法1: 重寫shouldComponentUpdate()方法比較新舊state或props數據, 如果有變化才返回true, 如果沒有返回false 辦法2: 使用PureComponentPureComponent重寫了shouldComponentUpdate(), 只有state或props數據有變化才返回true注意: 只是進行state和props數據的淺比較, 如果只是數據對象內部數據變了, 返回false 不要直接修改state數據, 而是要產生新數據 項目中一般使用PureComponent來優化

    總結

    以上是生活随笔為你收集整理的reactjs组件优化:setState的反复render问题的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。