蚂蚁设计表配置

时间:2020-01-24 19:04:05

标签: javascript reactjs antd ant-design-pro

我正在使用Ant Design Table组件,但无法找出用于扩展属性与根表进行比较的不同列结构。

现在,如果运行下面的代码,您将找到父列结构和子列,或者可能会说扩展表结构是相同的。

我想知道如何使父列和子列的结构不同。

注意:我不能使用“ expandedRowRender”属性,因为我们不想显示每一行的extension属性。

Structer shown in this image

      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'),
);

1 个答案:

答案 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
}