ant-design/components/table/demo/row-selection-custom.md

99 lines
2.2 KiB
Markdown
Raw Normal View History

---
order: 4
title:
en-US: Custom selection
zh-CN: 自定义选择项
---
## zh-CN
通过 `rowSelection.selections` 自定义选择项,默认不显示下拉选项,设为 `true` 时显示默认选择项。
## en-US
Use `rowSelection.selections` custom selections, default no select dropdown, show default selections via setting to `true`.
2019-05-07 14:57:32 +08:00
```jsx
import { Table } from 'antd';
2019-05-07 14:57:32 +08:00
const columns = [
{
title: 'Name',
dataIndex: 'name',
},
{
title: 'Age',
dataIndex: 'age',
},
{
title: 'Address',
dataIndex: 'address',
},
];
const data = [];
for (let i = 0; i < 46; i++) {
data.push({
key: i,
name: `Edward King ${i}`,
age: 32,
address: `London, Park Lane no. ${i}`,
});
}
class App extends React.Component {
state = {
2017-10-09 13:23:20 +08:00
selectedRowKeys: [], // Check here to configure the default column
};
2018-06-27 15:55:04 +08:00
2019-05-07 14:57:32 +08:00
onSelectChange = selectedRowKeys => {
console.log('selectedRowKeys changed: ', selectedRowKeys);
this.setState({ selectedRowKeys });
2019-05-07 14:57:32 +08:00
};
2018-06-27 15:55:04 +08:00
render() {
const { selectedRowKeys } = this.state;
const rowSelection = {
selectedRowKeys,
onChange: this.onSelectChange,
2019-05-07 14:57:32 +08:00
selections: [
Table.SELECTION_ALL,
Table.SELECTION_INVERT,
Table.SELECTION_NONE,
2019-05-07 14:57:32 +08:00
{
key: 'odd',
text: 'Select Odd Row',
onSelect: changableRowKeys => {
let newSelectedRowKeys = [];
newSelectedRowKeys = changableRowKeys.filter((key, index) => {
if (index % 2 !== 0) {
return false;
}
return true;
2019-05-07 14:57:32 +08:00
});
this.setState({ selectedRowKeys: newSelectedRowKeys });
},
},
{
key: 'even',
text: 'Select Even Row',
onSelect: changableRowKeys => {
let newSelectedRowKeys = [];
newSelectedRowKeys = changableRowKeys.filter((key, index) => {
if (index % 2 !== 0) {
return true;
}
return false;
});
this.setState({ selectedRowKeys: newSelectedRowKeys });
},
},
2019-05-07 14:57:32 +08:00
],
};
2019-05-07 14:57:32 +08:00
return <Table rowSelection={rowSelection} columns={columns} dataSource={data} />;
}
}
ReactDOM.render(<App />, mountNode);
2019-05-07 14:57:32 +08:00
```