ant-design/components/table/demo/fixed-columns-header.md

119 lines
2.7 KiB
Markdown
Raw Normal View History

2016-03-31 09:40:55 +08:00
---
order: 20
2016-08-15 07:54:01 +08:00
title:
en-US: Fixed Columns and Header
zh-CN: 固定头和列
2016-03-31 09:40:55 +08:00
---
2016-03-24 16:16:37 +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
2019-11-01 10:41:07 +08:00
> 若列头与内容不对齐或出现列重复,请指定**固定列**的宽度 `width`。如果指定 `width` 不生效或出现白色垂直空隙,请尝试建议留一列不设宽度以适应弹性布局,或者检查是否有[超长连续字段破坏布局](https://github.com/ant-design/ant-design/issues/13825#issuecomment-449889241)。
>
2017-02-22 12:33:08 +08:00
> 建议指定 `scroll.x` 为大于表格宽度的固定值或百分比。注意,且非固定列宽度之和不要超过 `scroll.x`。
2017-02-18 16:49:34 +08:00
2016-08-15 08:07:03 +08:00
## en-US
2016-08-15 07:54:01 +08:00
2017-02-18 16:49:34 +08:00
A Solution for displaying large amounts of data with long columns.
2019-11-01 10:41:07 +08:00
> Specify the width of columns if header and cell do not align properly. If specified width is not working or have gutter between columns, please try to leave one column at least without width to fit fluid layout, or make sure no [long word to break table layout](https://github.com/ant-design/ant-design/issues/13825#issuecomment-449889241).
>
> A fixed value which is greater than table width for `scroll.x` is recommended. The sum of unfixed columns should not greater than `scroll.x`.
2016-08-15 07:54:01 +08:00
```tsx
import React from 'react';
2016-03-24 16:16:37 +08:00
import { Table } from 'antd';
import type { ColumnsType } from 'antd/lib/table';
2016-03-24 16:16:37 +08:00
interface DataType {
key: React.Key;
name: string;
age: number;
address: string;
}
const columns: ColumnsType<DataType> = [
2018-11-28 15:00:03 +08:00
{
2019-05-07 14:57:32 +08:00
title: 'Full Name',
width: 100,
dataIndex: 'name',
key: 'name',
fixed: 'left',
2018-11-28 15:00:03 +08:00
},
{
2019-05-07 14:57:32 +08:00
title: 'Age',
width: 100,
dataIndex: 'age',
key: 'age',
fixed: 'left',
2018-11-28 15:00:03 +08:00
},
{
2019-05-07 14:57:32 +08:00
title: 'Column 1',
dataIndex: 'address',
key: '1',
width: 150,
2018-11-28 15:00:03 +08:00
},
{
2019-05-07 14:57:32 +08:00
title: 'Column 2',
dataIndex: 'address',
key: '2',
width: 150,
2018-11-28 15:00:03 +08:00
},
{
2019-05-07 14:57:32 +08:00
title: 'Column 3',
dataIndex: 'address',
key: '3',
width: 150,
2018-11-28 15:00:03 +08:00
},
{
2019-05-07 14:57:32 +08:00
title: 'Column 4',
dataIndex: 'address',
key: '4',
width: 150,
2018-11-28 15:00:03 +08:00
},
{
2019-05-07 14:57:32 +08:00
title: 'Column 5',
dataIndex: 'address',
key: '5',
width: 150,
2018-11-28 15:00:03 +08:00
},
{
2019-05-07 14:57:32 +08:00
title: 'Column 6',
dataIndex: 'address',
key: '6',
width: 150,
2018-11-28 15:00:03 +08:00
},
{
2019-05-07 14:57:32 +08:00
title: 'Column 7',
dataIndex: 'address',
key: '7',
width: 150,
2018-11-28 15:00:03 +08:00
},
2016-10-17 20:43:00 +08:00
{ title: 'Column 8', dataIndex: 'address', key: '8' },
2016-03-24 16:16:37 +08:00
{
title: 'Action',
2016-03-24 16:16:37 +08:00
key: 'operation',
fixed: 'right',
width: 100,
render: () => <a>action</a>,
2016-03-24 16:16:37 +08:00
},
];
const data: DataType[] = [];
2016-03-24 16:16:37 +08:00
for (let i = 0; i < 100; i++) {
data.push({
key: i,
2016-10-02 08:55:40 +08:00
name: `Edrward ${i}`,
2016-03-24 16:16:37 +08:00
age: 32,
2016-10-02 08:55:40 +08:00
address: `London Park no. ${i}`,
2016-03-24 16:16:37 +08:00
});
}
const App: React.FC = () => (
<Table columns={columns} dataSource={data} scroll={{ x: 1500, y: 300 }} />
);
export default App;
2019-05-07 14:57:32 +08:00
```