欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決react組件渲染兩次的問(wèn)題

 更新時(shí)間:2022年08月04日 11:35:11   作者:神才飛揚(yáng)  
這篇文章主要介紹了解決react組件渲染兩次的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

react組件渲染兩次

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

如果你使用了react-router低于4.x版本中的hashHistory,那么問(wèn)題就來(lái)了,出現(xiàn)這種情況的原因是因?yàn)閞outer中進(jìn)行了一次push和一次pop,所以出現(xiàn)兩次渲染,

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

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

或者

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

只要二選一即可解決渲染兩次的問(wèn)題。 

react總結(jié)之避免不必要的重復(fù)渲染

類組件PureComponent

適當(dāng)?shù)氖褂肞ureComponent創(chuàng)建組件可以提高性能,在使用類組件的時(shí)侯,繼承PureComponent組件,它是依賴于傳遞給組件的props進(jìn)行淺比較,當(dāng)props發(fā)生改變的時(shí)候,才會(huì)重新渲染組件,既然是淺比較,那么在state和props每次都發(fā)生改變的額時(shí)候,還要使用PureComponent就會(huì)對(duì)性能產(chǎn)生負(fù)面的影響了!

  • React.memo()

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

  • shouldComponmentUpdate

類組件的的生命周期函數(shù),當(dāng)返回值是false的時(shí)候,視圖不做更新,否則更新!

使用插件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;

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • React項(xiàng)目中fetch實(shí)現(xiàn)跨域接收傳遞session的解決方案

    React項(xiàng)目中fetch實(shí)現(xiàn)跨域接收傳遞session的解決方案

    這篇文章主要介紹了React項(xiàng)目中fetch實(shí)現(xiàn)跨域接收傳遞session的解決方案,本次項(xiàng)目使用了react框架,同時(shí)使用fetch取代ajax作為獲取接口數(shù)據(jù)的交互方法,下面就對(duì)這次問(wèn)題的解決做個(gè)總結(jié),需要的朋友可以參考下
    2022-04-04
  • react 兄弟組件如何調(diào)用對(duì)方的方法示例

    react 兄弟組件如何調(diào)用對(duì)方的方法示例

    這篇文章主要介紹了react 兄弟組件如何調(diào)用對(duì)方的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • React中super()和super(props)的區(qū)別小結(jié)

    React中super()和super(props)的區(qū)別小結(jié)

    本文主要介紹了React中super()和super(props)的區(qū)別小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-03-03
  • 30行代碼實(shí)現(xiàn)React雙向綁定hook的示例代碼

    30行代碼實(shí)現(xiàn)React雙向綁定hook的示例代碼

    本文主要介紹了30行代碼實(shí)現(xiàn)React雙向綁定hook的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • 關(guān)于React中setState同步或異步問(wèn)題的理解

    關(guān)于React中setState同步或異步問(wèn)題的理解

    相信很多小伙伴們都一直在疑惑,setState 到底是同步還是異步。本文就詳細(xì)的介紹一下React中setState同步或異步問(wèn)題,感興趣的可以了解一下
    2021-11-11
  • 解決react中useState狀態(tài)異步更新的問(wèn)題

    解決react中useState狀態(tài)異步更新的問(wèn)題

    本文主要介紹了react中useState狀態(tài)異步更新的問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 使用react-native-doc-viewer實(shí)現(xiàn)文檔預(yù)覽

    使用react-native-doc-viewer實(shí)現(xiàn)文檔預(yù)覽

    這篇文章主要介紹了使用react-native-doc-viewer實(shí)現(xiàn)文檔預(yù)覽,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • 詳解React Fiber的工作原理

    詳解React Fiber的工作原理

    這篇文章主要介紹了React Fiber的工作原理的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用React框架,感興趣的朋友可以了解下
    2021-04-04
  • 詳解react-router-dom v6版本基本使用介紹

    詳解react-router-dom v6版本基本使用介紹

    本文主要介紹了react-router-dom v6版本基本使用介紹,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 淺析JS中什么是自定義react數(shù)據(jù)驗(yàn)證組件

    淺析JS中什么是自定義react數(shù)據(jù)驗(yàn)證組件

    我們?cè)谧銮岸吮韱翁峤粫r(shí),經(jīng)常會(huì)遇到要對(duì)表單中的數(shù)據(jù)進(jìn)行校驗(yàn)的問(wèn)題。這篇文章主要介紹了js中什么是自定義react數(shù)據(jù)驗(yàn)證組件,需要的朋友可以參考下
    2018-10-10

最新評(píng)論