本文主要是介绍【React】Table表头纵向展示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
默认表格展示:
展示目标:
环境
antd
: ^5.14.1react
: ^18
拟定数据
- columns
const columns = [{title: "品牌",dataIndex: "brand",key: "brand",width: 100,},{title: "Star",dataIndex: "star",key: "star",width: 100,}
];
- dataSource
const dataSource = [{key: "1",brand: "logitech",star: 4.3},{key: "2",brand: "NexiGo",star: 3.1},{key: "3",brand: "logitech2",star: 4.3},{key: "4",brand: "NexiGo2",star: 3.1},{key: "5",brand: "NexiGo3",star: 3.1},{key: "6",brand: "NexiGo4",star: 3.1},{key: "7",brand: "NexiGo5",star: 3.1},{key: "8",brand: "NexiGo6",star: 3.1},
];
测试组件
import type { TableProps } from "antd";import { useEffect, useState } from "react";
import { Table } from "antd";
import { transformData } from "./unit";type Props = {dataSource: any[];columns: string[];
};export const TestTable = function (props: Props) {const [tableList, setTableList] = useState<any>([]);const [tableColumns, setTableColumns] = useState<any[]>([]);useEffect(() => {const { columns, data } = transformData(props.dataSource);setTableColumns(columns)setTableList(data);}, []);return (<Tablecolumns={tableColumns}dataSource={tableList}borderedscroll={{ x: "100%", y: "auto" }}showHeader={true}pagination={false}/>);
};export default TestTable;
数据转换:
// file: ./unit.ts
export function transformData(originalData: any[]) {let keys = Object.keys(originalData[0]).filter((key) => key !== "key");let columns = [{ title: "first", dataIndex: "first", key: "first" }];originalData.forEach((key, index) => {columns.push({title: `col${index + 1}`,dataIndex: `col${index + 1}`,key: `col${index + 1}`,});});let transformedData = keys.map((key, index) => {let rowData: any = { key: `${index + 1}` };originalData.forEach((item, idx) => {rowData[`col${idx + 1}`] = item[key];});rowData.first = key;return rowData;});return { columns, data: transformedData };
}
这篇关于【React】Table表头纵向展示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!