第一个功能 如何渲染
参照官网案例
const dataSource = [ { key: '1', name: '胡彦斌', age: 32, address: '西湖区湖底公园1号', }, { key: '2', name: '胡彦祖', age: 42, address: '西湖区湖底公园1号', }, ]; const columns = [ { title: '姓名', dataIndex: 'name', key: 'name', }, { title: '年龄', dataIndex: 'age', key: 'age', }, { title: '住址', dataIndex: 'address', key: 'address', }, ]; <Table dataSource={dataSource} columns={columns} />;
当我们看完了这个基础案例以后 相信我们就已经清楚该定义数据格式了
最终数据格式
结果(解决)
第二个功能 如何合并
直接看全部代码 进行重点讲解
定义处理column哥的方法 加入render
const handleColumn = (columns) => { for (let i = 0; i < columns.length; i++) { if (columns[i]?.dataIndex == "cuttingName") { columns[i].render = data } else if (columns[i]?.dataIndex == "colorName") { columns[i].render = dataColor } } return columns }
datacolor处理合并逻辑
datacolor是一个函数 下面看我的定义
const dataColor = (value, row, index) => { const obj = { children: value, props: { rowSpan: 1 }, } if (columns.length > 0) { return filterNumData(obj, dataSource, row, index, 'colorName') } else { return obj } }
if判断特别关键 不然刚刷新页面就会报错 因为render找不到对应属性
filterNumData处理合并逻辑核心
const filterNumData = (obj, arr, record, index, flag) => { let length = 0 if (arr.length > 0) { for (let i = index; i < arr.length; i++) { if (i === arr.length - 1 && arr.length != 1) { if (arr[i - 1][`${flag}`] === record[`${flag}`]) { length += 1 break } } else { if (arr[i][`${flag}`] === record[`${flag}`]) { length += 1 } else { break } } } }
五个属性 我们分别讲解 obj 自己定义了 看如上 const obj = { children: value, props: { rowSpan: 1 }, } dataSource返回的数据
row render自带 index render自带 colorName 要合并的属性 最后重新setState columns 合并完成