中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

react組件渲染兩次問題如何解決

發布時間:2022-08-04 14:08:04 來源:億速云 閱讀:252 作者:iii 欄目:開發技術

這篇文章主要介紹“react組件渲染兩次問題如何解決”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“react組件渲染兩次問題如何解決”文章能幫助大家解決問題。

react組件渲染兩次

可能會有人問,問什么我的組件明明是就讓渲染一次,但是實際上卻渲染兩次呢?其實我也遇到了這個問題,那么下面我提出一種解決這個問題的一種方法。

如果你使用了react-router低于4.x版本中的hashHistory,那么問題就來了,出現這種情況的原因是因為router中進行了一次push和一次pop,所以出現兩次渲染,

你只需要在shouldComponentUpdate()這個生命周期鉤子中做一個判斷就好了:

return (this.props.router.location.action === 'PUSH')

或者

return (this.props.router.location.action === 'POP');

只要二選一即可解決渲染兩次的問題。 

react總結之避免不必要的重復渲染

類組件PureComponent

適當的使用PureComponent創建組件可以提高性能,在使用類組件的時侯,繼承PureComponent組件,它是依賴于傳遞給組件的props進行淺比較,當props發生改變的時候,才會重新渲染組件,既然是淺比較,那么在state和props每次都發生改變的額時候,還要使用PureComponent就會對性能產生負面的影響了!

  • React.memo()

React.memo()和PureComponent很相似,PureComponent是一個類,React.memo()是一個函數組件,它有兩個參數,第一個參數是純函數的組件,第二個參數是true或者false,用于控制是否刷新組件!

  • shouldComponmentUpdate

類組件的的生命周期函數,當返回值是false的時候,視圖不做更新,否則更新!

使用插件seamless-immutable

1.引入import Immutable from 'seamless-immutable';

2.初始化state

    this.state = {
                    list: Immutable([]);
    }

3.修改state

    this.setState({
                list: Immutable(items);
    })

使用插件pure-render-decorator

import React from 'react';
import pureRender from 'pure-render-decorator';
// es7才支持裝飾器,這邊需要配置babel
@pureRender
class List extends React.Component {
  render() {
    const {list} = this.props;
    return (
      <>
        {
          list.map((item) => {
            return (
              <div key={item.id}>
                <div>{item.code}</div>
              </div>
            );
          })
        }
      </>
    );
  }
}
export default List;

關于“react組件渲染兩次問題如何解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兴文县| 耒阳市| 尤溪县| 岢岚县| 宁国市| 金溪县| 阜阳市| 柘城县| 霍山县| 收藏| 勐海县| 桑植县| 杭州市| 介休市| 灵寿县| 安岳县| 宁都县| 大方县| 新巴尔虎左旗| 托克逊县| 肇源县| 萨迦县| 锡林浩特市| 白玉县| 延庆县| 新巴尔虎左旗| 巧家县| 佛坪县| 杂多县| 韩城市| 永胜县| 宜宾县| 江口县| 连云港市| 即墨市| 上虞市| 石林| 水城县| 漳州市| 秦安县| 夏邑县|