我正在使用Ant Design Table组件,但无法找出用于扩展属性与根表进行比较的不同列结构。
现在,如果运行下面的代码,您将找到父列结构和子列,或者可能会说扩展表结构是相同的。
我想知道如何使父列和子列的结构不同。
注意:我不能使用“ expandedRowRender”属性,因为我们不想显示每一行的extension属性。
NAME(Column Name) Age Address
Mick 1 New York No. 1 Lake Park
+ John Brown sr. 2 New York No. 2 Lake Park
Name Age Address
John Brown 1 New York No. 1 Lake Park
Any Name 2 New York No. 2 Lake Park
Amey 3 New York No. 3 Lake Park
您可以看到第1级和第2级列的结构是相同的,我试图弄清楚如何给出不同的结构,并且您看到所有行都没有扩展属性。只有第二行具有该属性。
如果无法以适当的方式提出问题,Sensior表示歉意。
import React from 'react';
import ReactDOM from 'react-dom';
import 'antd/dist/antd.css';
import './index.css';
import { Table } from 'antd';
const columns = [
{
title: 'Name',
dataIndex: 'name',
key: 'name',
},
{
title: 'Age',
dataIndex: 'age',
key: 'age',
width: '12%',
},
{
title: 'Address',
dataIndex: 'address',
width: '30%',
key: 'address',
}
];
const data = [
{
key: 1,
name: 'John Brown sr.',
age: 60,
address: 'New York No. 1 Lake Park',
children: [
{
key: 11,
aa: 11111,
bb: 22222,
name: 'John Brown',
age: 42,
address: 'New York No. 2 Lake Park',
},
{
key: 12,
name: 'John Brown jr.',
age: 30,
address: 'New York No. 3 Lake Park',
children: [
{
key: 121,
name: 'Jimmy Brown',
age: 16,
address: 'New York No. 3 Lake Park',
},
],
},
{
key: 13,
name: 'Jim Green sr.',
age: 72,
address: 'London No. 1 Lake Park',
children: [
{
key: 131,
name: 'Jim Green',
age: 42,
address: 'London No. 2 Lake Park',
children: [
{
key: 1311,
name: 'Jim Green jr.',
age: 25,
address: 'London No. 3 Lake Park',
},
{
key: 1312,
name: 'Jimmy Green sr.',
age: 18,
address: 'London No. 4 Lake Park',
},
],
},
],
},
],
},
{
key: 2,
name: 'Joe Black',
age: 32,
address: 'Sidney No. 1 Lake Park',
},
];
ReactDOM.render(
<Table columns={columns} dataSource={data} />,
document.getElementById('container'),
);
答案 0 :(得分:0)
注意:我不能使用“ expandedRowRender”属性,因为我们不想显示每一行的extension属性。
我不得不做类似的事情。因此,我使用了expandRowRender和行的不同类名(基于它们是否具有扩展属性(item.children)),并使用css属性来隐藏没有孩子的行上的扩展按钮。
.class_name_to_hide_expand .ant-table-row-expand-icon-cell .ant-table-row-expand-icon{
opacity: 0;
pointer-events: none
}