2016-03-31 09:40:55 +08:00
|
|
|
---
|
2019-11-15 14:35:25 +08:00
|
|
|
order: 14
|
2016-08-15 07:54:01 +08:00
|
|
|
title:
|
|
|
|
en-US: Expandable Row
|
|
|
|
zh-CN: 可展开
|
2016-03-31 09:40:55 +08:00
|
|
|
---
|
2015-09-10 11:04:31 +08:00
|
|
|
|
2016-08-15 08:07:03 +08:00
|
|
|
## zh-CN
|
2016-08-15 07:54:01 +08:00
|
|
|
|
2016-08-15 08:07:03 +08:00
|
|
|
当表格内容较多不能一次性完全展示时。
|
2016-08-15 07:54:01 +08:00
|
|
|
|
2016-08-15 08:07:03 +08:00
|
|
|
## en-US
|
2016-08-15 07:54:01 +08:00
|
|
|
|
2016-08-15 08:07:03 +08:00
|
|
|
When there's too much information to show and the table can't display all at once.
|
2015-09-10 11:04:31 +08:00
|
|
|
|
2022-05-19 09:46:26 +08:00
|
|
|
```tsx
|
2015-10-28 20:55:49 +08:00
|
|
|
import { Table } from 'antd';
|
2022-07-04 22:09:54 +08:00
|
|
|
import type { ColumnsType } from 'antd/es/table';
|
2022-05-23 14:37:16 +08:00
|
|
|
import React from 'react';
|
2015-09-10 11:04:31 +08:00
|
|
|
|
2022-05-19 09:46:26 +08:00
|
|
|
interface DataType {
|
|
|
|
key: React.Key;
|
|
|
|
name: string;
|
|
|
|
age: number;
|
|
|
|
address: string;
|
|
|
|
description: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const columns: ColumnsType<DataType> = [
|
2016-10-02 08:37:51 +08:00
|
|
|
{ title: 'Name', dataIndex: 'name', key: 'name' },
|
|
|
|
{ title: 'Age', dataIndex: 'age', key: 'age' },
|
|
|
|
{ title: 'Address', dataIndex: 'address', key: 'address' },
|
2018-11-28 15:00:03 +08:00
|
|
|
{
|
2019-05-07 14:57:32 +08:00
|
|
|
title: 'Action',
|
|
|
|
dataIndex: '',
|
|
|
|
key: 'x',
|
2019-08-14 19:36:59 +08:00
|
|
|
render: () => <a>Delete</a>,
|
2018-11-28 15:00:03 +08:00
|
|
|
},
|
2015-09-10 11:04:31 +08:00
|
|
|
];
|
|
|
|
|
2022-05-19 09:46:26 +08:00
|
|
|
const data: DataType[] = [
|
2018-11-28 15:00:03 +08:00
|
|
|
{
|
2019-05-07 14:57:32 +08:00
|
|
|
key: 1,
|
|
|
|
name: 'John Brown',
|
|
|
|
age: 32,
|
|
|
|
address: 'New York No. 1 Lake Park',
|
|
|
|
description: 'My name is John Brown, I am 32 years old, living in New York No. 1 Lake Park.',
|
2018-11-28 15:00:03 +08:00
|
|
|
},
|
|
|
|
{
|
2019-05-07 14:57:32 +08:00
|
|
|
key: 2,
|
|
|
|
name: 'Jim Green',
|
|
|
|
age: 42,
|
|
|
|
address: 'London No. 1 Lake Park',
|
|
|
|
description: 'My name is Jim Green, I am 42 years old, living in London No. 1 Lake Park.',
|
2018-11-28 15:00:03 +08:00
|
|
|
},
|
|
|
|
{
|
2019-05-07 14:57:32 +08:00
|
|
|
key: 3,
|
2019-11-15 14:35:25 +08:00
|
|
|
name: 'Not Expandable',
|
|
|
|
age: 29,
|
|
|
|
address: 'Jiangsu No. 1 Lake Park',
|
|
|
|
description: 'This not expandable',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: 4,
|
2019-05-07 14:57:32 +08:00
|
|
|
name: 'Joe Black',
|
|
|
|
age: 32,
|
|
|
|
address: 'Sidney No. 1 Lake Park',
|
|
|
|
description: 'My name is Joe Black, I am 32 years old, living in Sidney No. 1 Lake Park.',
|
2018-11-28 15:00:03 +08:00
|
|
|
},
|
2015-09-10 11:04:31 +08:00
|
|
|
];
|
|
|
|
|
2022-05-19 09:46:26 +08:00
|
|
|
const App: React.FC = () => (
|
2016-09-20 13:16:58 +08:00
|
|
|
<Table
|
|
|
|
columns={columns}
|
2019-11-15 14:35:25 +08:00
|
|
|
expandable={{
|
|
|
|
expandedRowRender: record => <p style={{ margin: 0 }}>{record.description}</p>,
|
|
|
|
rowExpandable: record => record.name !== 'Not Expandable',
|
|
|
|
}}
|
2016-04-29 12:13:27 +08:00
|
|
|
dataSource={data}
|
2022-04-03 23:27:45 +08:00
|
|
|
/>
|
2018-11-28 15:00:03 +08:00
|
|
|
);
|
2022-05-19 09:46:26 +08:00
|
|
|
|
|
|
|
export default App;
|
2019-05-07 14:57:32 +08:00
|
|
|
```
|