一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - React - React antd tabs切換造成子組件重復刷新

React antd tabs切換造成子組件重復刷新

2022-02-22 16:41一堆亂碼 React

這篇文章主要介紹了React antd tabs切換造成子組件重復刷新,需要的朋友可以參考下

描述:

Tabs組件在來回切換的過程中,造成TabPane中包含的相同子組件重復渲染,例如:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<Tabs
 activeKey={tabActiveKey}
 onChange={(key: string) => this.changeTab(key)}
 type="card"
>
  <TabPane tab={"對外授權"} key="/authed-by-me">
    <AuthedCollections
        collectionType={this.collectionType}
     />
  </TabPane>
  <TabPane tab={"申請權限"} key="/authed-to-me">
    <AuthedCollections
      collectionType={this.collectionType}
     />
  </TabPane>
</Tabs>
 
 
changeTab = (key: string) => {
 this.collectionType = key === '/authed-by-me' ? CollectionEnums.AUTHED_TO_GRANT : CollectionEnums.AUTHED_TO_APPLY;
 this.setState({
  tabActiveKey: key
 })
};

分析:

在Tabs的onChange監聽函數changeTab中調用setState,造成頁面重新render。antd 的策略是,只渲染當前的。當用戶切換過后,不刪除之前渲染過的節點。所以點擊切換會逐漸增多。為的是防止用戶在 mount 階段調用異步請求導致切換時反復渲染。所以 render 數量隨著上層刷新而整體刷新并增加是預期行為。

解決方案:

運用react的條件渲染,在每一次tab切換的時候將上個頁面移出Dom樹

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<Tabs
 activeKey={tabActiveKey}
 onChange={(key: string) => this.changeTab(key)}
 type="card"
>
 <TabPane tab={"對外授權"} key="">
 {
 this.collectionType === CollectionEnums.AUTHED_TO_GRANT &&
 <AuthedCollections
 collectionType={this.collectionType}
 />
 }
 </TabPane>
 <TabPane tab={"申請權限"} key="/authed-to-me">
 {
 this.collectionType === CollectionEnums.AUTHED_TO_APPLY &&
 <AuthedCollections
 collectionType={this.collectionType}
 />
 }
 </TabPane>
</Tabs>

Antd Tabs 當前頁面來回切換 表單數據不清空(或者清空)

清空表單的辦法是this.props.form.resetFields();

但是本篇文章主要講解不清空

靈活使用 display:none 就可以避免切換的時候表單數據被setState重新渲染清空掉 (即切換tab項,不清空表單)

React antd tabs切換造成子組件重復刷新

React antd tabs切換造成子組件重復刷新

查詢區域

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
{/* 查詢區域 */}
    <div className="search-form-area">
     {
      <div style={{ display: activeKey === '1' ? 'block' : 'none' }}><SearchFieldForm // 項目角度
       ref={(form) => this.ProjSearchForm = form}
       submitFuc={this.getProjPage}
       fieldsData={projSearchData}
       colNum={4}
       diyItemLayout={{ labelCol: { span: 4 }, wrapperCol: { span: 17 } }}
      // moreSearchData={moreSearchData}
      /></div>
     }
     {
      <div style={{ display: activeKey === '2' ? 'block' : 'none' }}>< SearchFieldForm // 產品角度
       ref={(form) => this.PrdSearchForm = form}
       submitFuc={this.getProjPage}
       fieldsData={prdSearchData}
       colNum={4}
       diyItemLayout={{ labelCol: { span: 4 }, wrapperCol: { span: 17 } }}
      /></div>
     }
    </div>

列表區域

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
 {/* 列表區域 */}
        <div style={{ height: tableHeight + 100 }} className='myProjTable'>
          <Tabs defaultActiveKey="1" onChange={this.handleTabsChange}>
            <TabPane tab="項目角度" key="1" style={{ backgroundColor: '#fff' }}>
              <CustomTable
                rowKey='projId'
                size="small"
                style={{ height: tableHeight }}
                columns={columns}
                tableData={projTableData}
                expandedRowRender={this.expandedRowRender}
                pagination={pagination}
                handleTableChange={this.handleTableChange}
                scroll={{ y: tableScrollHeight, x: 1660 }}
                tableRowSelection={this.tableRowSelection}
              />
            </TabPane>
            <TabPane tab="產品角度" key="2" style={{ backgroundColor: '#fff' }}>
              <CustomTable
                rowKey="projId"
                size="small"
                style={{ height: tableHeight }}
                columns={columnsPrd}
                tableData={prdTableData}
                handleTableChange={this.handleTableChange}
                pagination={pagination}
                scroll={{ y: tableScrollHeight, x: 1800 }}
                tableRowSelection={this.tableRowSelection}
              />
            </TabPane>
          </Tabs>
        </div>

到此這篇關于React antd tabs切換造成子組件重復刷新的文章就介紹到這了,更多相關antd tabs重復刷新內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/TZ2318387771/article/details/108503639

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91韩国女主播 | 国产精品网页 | 日韩在线视频一区二区三区 | 色啊色| 精品国产品在线18年 | poren18美女 | 久久99re2在线视频精品 | 亚洲国产在线播放在线 | 久久精品中文字幕 | 91这里只有精品 | julia ann黑人巨大 | 日韩一区视频在线 | 91在线 一区 二区三区 | 欧洲网色偷偷亚洲男人的天堂 | 精品国产精品国产偷麻豆 | 亚洲国产日韩欧美一区二区三区 | 美女无内裤下部黄 | 欧美人与牲动交xxx 欧美人妖另类性hd 欧美人人干 | 天美蜜桃精东乌鸦传媒 | 男女发生性关系视频 | 亚洲青草视频 | 俄罗斯一级在线播放 | 国产免费资源 | 大乳奶水bbw | 精品视频 久久久 | 污文啊好棒棒啊好了 | 水蜜桃一二二区视在线 | 被巨大黑人的翻白眼 | 我要看逼 | 久久久精品日本一区二区三区 | 亚洲天堂成人在线 | 3d动漫h在线观看网站蜜芽 | 国产精品香蕉夜间视频免费播放 | 91嫩草私人成人亚洲影院 | 色五夜婷婷 | 麻麻与子乱肉小说怀孕 | 日本伊人久久 | 四虎影院在线免费观看视频 | 久久棋牌评测 | 成人在线观看视频免费 | 欧美成人乱弄视频 |