IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> antd Table表格分页数据为动态获取时,切换页码后保留之前页面选中数据状态的实现,以及数据刷新后选中状态仍保留问题的解决 -> 正文阅读

[JavaScript知识库]antd Table表格分页数据为动态获取时,切换页码后保留之前页面选中数据状态的实现,以及数据刷新后选中状态仍保留问题的解决

问题:

antd Table提供了数据行可选择的操作,但是如果分页数据是从后端获取,切换页码后之前的分页数据就没有了,回到之前的页面选中状态也无法保留。

解决:

这里对ant Table表格组件进行了封装,实现了在分页数据动态获取时切换页码其他页选中的数据和状态仍保留的功能

思路:

1.定义curPageSelectedRowKeys存储当前页选中数据的key值数组,selectedRows存储所有选中数据
2.监听当前页数据选中/取消选中和全选/取消全选操作,更新curPageSelectedRowKeys和selectedRows
3.当页码切换时根据selectedRows来确定当前页面哪些数据是选中状态从而确定curPageSelectedRowKeys

组件代码:

/*
 * @Author: liu
 * @Date: 2021-08-24 14:35:53
 * @LastEditTime: 2021-09-08 22:11:01
 * @LastEditors: Please set LastEditors
 * @Description: 表格自定义选中项,前端分页,分页后保留之前选中数据
 * @FilePath: \chq-datamarket-frontend\src\apps\views\shared\customSelectTable\customSelectTable.tsx
 */
import React, { useEffect, useState } from "react";
import { Pagination, Table } from "antd";
interface CustomSelectTableProps {
  columns: any[]; //表格列
  dataSource: any[]; //表格数据(当前页)
  curPageSelectedRowKeys: number[]; //当前页选中数据key值数组
  curPageSelectedRowKeysChange: (key: any[]) => void; //curPageSelectedRowKeys改变
  selectedRows: any[]; //所有选中数据
  selectedRowsChange: (row: any[]) => void;
  pageOption: {
    //分页参数
    page: number;
    pageChange: (page) => void;
    pageSize: number;
    sizeChange: (size: number) => void;
    totalCount: number;
    showSizeChanger?: boolean;
    pageSizeOptions?: any[];
  };
  tableClass?: string;
}
export default function customSelectTable(props: CustomSelectTableProps) {
  useEffect(() => {
    updateSelectData();
  }, [props.dataSource]);

  const rowSelection = {
    selectedRowKeys: props.curPageSelectedRowKeys,
    onSelect: (record, selected, selectedRows, nativeEvent) => {
      onSelectChange(record, selected, selectedRows);
    },
    onSelectAll: onSelectAll,
    hideDefaultSelections: true
  };
  /**
   * 更新选中数据,当表格数据变化后,重新计算当前页选中数据
   */
  function updateSelectData() {
    const curPageSelectIndex = [];
    const { selectedRows } = props;
    if (selectedRows && selectedRows.length) {
      props.dataSource.map(d => {
        selectedRows.find(sd => {
          //key是数据的唯一标识,需要在dataSource中确定每条数据的key值
          if (d.key === sd.key) {
            curPageSelectIndex.push(d.key);
            return true;
          }
        });
      });
    }
    props.curPageSelectedRowKeysChange(curPageSelectIndex);
  }
  /**
   * 数据选中/取消选中
   * @param record 当前操作数据
   * @param selected 是否选中
   * @param selectedRows 当前页所有选中数据
   */
  function onSelectChange(record, selected, selectedRows) {
    props.curPageSelectedRowKeysChange(selectedRows.map(it => it.key));
    if (selected) {
      props.selectedRowsChange([...props.selectedRows, record]);
    } else {
      const selectedrows = props.selectedRows.filter(it => {
        return it.key !== record.key;
      });
      props.selectedRowsChange(selectedrows);
    }
  }
  //全选操作
  function onSelectAll(selected: any, selectedRows: any, changeRows: any) {
    props.curPageSelectedRowKeysChange(selectedRows.map(it => it.key));
    const changeRowsId: string[] = changeRows.map(it => {
      return it.key;
    });
    if (selected) {
      props.selectedRowsChange([...props.selectedRows, ...changeRows]);
    } else {
      const selectrows = props.selectedRows.filter(it => {
        return !changeRowsId.includes(it.key);
      });
      props.selectedRowsChange(selectrows);
    }
  }
  function pageChange(page) {
    props.pageOption.pageChange(page);
  }
  function pageSizeChange(cur, size) {
    props.pageOption.sizeChange(size);
  }
  return (
    <>
      <Table
        columns={props.columns}
        dataSource={props.dataSource}
        className={`tableBase ${props.tableClass}`}
        rowSelection={rowSelection}
        pagination={false}
      />
      <div className="commonPage">
        <div className="pageDesc">{`每页${props.pageOption.pageSize}条记录,共${props.pageOption.totalCount}`}</div>
        <Pagination
          className="dataPage"
          current={props.pageOption.page}
          pageSize={props.pageOption.pageSize}
          showSizeChanger={props.pageOption.showSizeChanger}
          pageSizeOptions={
            props.pageOption.pageSizeOptions || ["15", "50", "100"]
          }
          onShowSizeChange={pageSizeChange}
          total={props.pageOption.totalCount}
          showQuickJumper={true}
          onChange={pageChange}
        />
      </div>
    </>
  );
}

使用示例:

import React, { Component } from "react";
import { Button, Input, Select, Pagination, message, Table } from "antd";
import CustomSelectTable from "../../../shared/customSelectTable/customSelectTable";
import { AppContext } from "../../../../utils/qe.util";
import "public/css/authorityApplication.css";

interface AuthorityApplicationProps {}
interface AuthorityApplicationStates {
  tableData: any[];
  curPageSelectedRowKeys: any[]; //当前页选中索引
  selectedRows: any[]; //所有选中数据(除当前页)
  page: number;
  pageSize: number;
  totalCount: number;
}
export default class AuthorityApplication extends Component<
  AuthorityApplicationProps,
  AuthorityApplicationStates
> {
  static contextType = AppContext;
  constructor(props) {
    super(props);
    this.state = {
      tableData: [],
      curPageSelectedRowKeys: [],
      selectedRows: [],
      page: 1,
      pageSize: 12,
      totalCount: 0
    };
  }
  componentDidMount() {
    this.getDataList();
  }
  private pageChange = page => {
    this.setState(
      {
        page
      },
      () => {
        this.getDataList();
      }
    );
  };
  private pageSizeChange = size => {
    this.setState(
      {
        pageSize: size,
        page: 1
      },
      () => {
        this.getDataList();
      }
    );
  };
  //获取表格数据
  private getDataList = () => {};

  private submit = () => {
    const { selectedRows } = this.state;
    new Promise(res => {
      //提交selectedRows
    }).then(() => {
      this.setState({
        curPageSelectedRowKeys: [],
        selectedRows: []
      });
    });
  };
  render() {
    const {
      tableData,
      curPageSelectedRowKeys,
      selectedRows,
      page,
      pageSize,
      totalCount
    } = this.state;
    const columns: any = [
      {
        title: "序号",
        align: "center",
        dataIndex: "key",
        render: (key: any, record: any, index: number) => Number(index) + 1
      },
      {
        title: "名称",
        dataIndex: "dataItemName",
        key: "dataItemName",
        align: "center"
      }
    ];
    return (
      <div className="authorityApplicationContainer">
        <CustomSelectTable
          columns={columns}
          dataSource={tableData}
          tableClass="commonTable scrollBase"
          curPageSelectedRowKeys={curPageSelectedRowKeys}
          curPageSelectedRowKeysChange={keys => {
            this.setState({
              curPageSelectedRowKeys: keys
            });
          }}
          selectedRows={selectedRows}
          selectedRowsChange={row => {
            this.setState({
              selectedRows: row
            });
          }}
          pageOption={{
            page,
            pageSize,
            pageChange: this.pageChange,
            sizeChange: this.pageSizeChange,
            totalCount,
            showSizeChanger: true,
            pageSizeOptions: ["12", "50", "100"]
          }}
        />
        <div>
          <Button onClick={this.submit}>提交</Button>
        </div>
      </div>
    );
  }
}

注意:

为了避免切换分页后前一页选中的状态在新数据页仍然保留的问题,在得到表格数据后为每条数据都加了key字段,其值可以为数据唯一标识对应的值如id,如果本身就有唯一的key字段则无需再添加。

this.setState({
   tableData: (res.result.content || []).map(it => {
     return { ...it, key: it.key || it.id };
   }),
 });

补充:

1.数据刷新后选中状态仍保留问题
如果选中了部分数据后,表格数据已经重新请求了,且curPageSelectedRowKeys和selectRoews都已经置空了,但是之前的选中状态仍然保留,查看Table的rowSelection属性是不是正确的设置了selectedRowKeys值(这里应该为curPageSelectedRowKeys),或者忘记添加selectedRowKeys

const rowSelection = {
    selectedRowKeys: props.curPageSelectedRowKeys,//就是这个字段,笔者就是当时把selectedRowKeys写错了,导致了上述问题
    onSelect: (record, selected, selectedRows, nativeEvent) => {
      onSelectChange(record, selected, selectedRows);
    },
    onSelectAll: onSelectAll,
    hideDefaultSelections: true
  };
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-09-09 11:39:18  更:2021-09-09 11:40:23 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/27 20:42:59-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计