mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-25 08:43:57 +08:00
136 lines
3.3 KiB
Markdown
136 lines
3.3 KiB
Markdown
---
|
|
order: 23
|
|
title:
|
|
en-US: Editable Rows
|
|
zh-CN: 可编辑行
|
|
---
|
|
|
|
## zh-CN
|
|
|
|
带行编辑功能的表格。
|
|
|
|
## en-US
|
|
|
|
Table with editable rows.
|
|
|
|
````jsx
|
|
import { Table, Input, Popconfirm } from 'antd';
|
|
|
|
const data = [];
|
|
for (let i = 0; i < 100; i++) {
|
|
data.push({
|
|
key: i.toString(),
|
|
name: `Edrward ${i}`,
|
|
age: 32,
|
|
address: `London Park no. ${i}`,
|
|
});
|
|
}
|
|
|
|
const EditableCell = ({ editable, value, onChange }) => (
|
|
<div>
|
|
{editable
|
|
? <Input style={{ margin: '-5px 0' }} value={value} onChange={e => onChange(e.target.value)} />
|
|
: value
|
|
}
|
|
</div>
|
|
);
|
|
|
|
class EditableTable extends React.Component {
|
|
constructor(props) {
|
|
super(props);
|
|
this.columns = [{
|
|
title: 'name',
|
|
dataIndex: 'name',
|
|
width: '25%',
|
|
render: (text, record) => this.renderColumns(text, record, 'name'),
|
|
}, {
|
|
title: 'age',
|
|
dataIndex: 'age',
|
|
width: '15%',
|
|
render: (text, record) => this.renderColumns(text, record, 'age'),
|
|
}, {
|
|
title: 'address',
|
|
dataIndex: 'address',
|
|
width: '40%',
|
|
render: (text, record) => this.renderColumns(text, record, 'address'),
|
|
}, {
|
|
title: 'operation',
|
|
dataIndex: 'operation',
|
|
render: (text, record) => {
|
|
const { editable } = record;
|
|
return (
|
|
<div className="editable-row-operations">
|
|
{
|
|
editable ?
|
|
<span>
|
|
<a onClick={() => this.save(record.key)}>Save</a>
|
|
<Popconfirm title="Sure to cancel?" onConfirm={() => this.cancel(record.key)}>
|
|
<a>Cancel</a>
|
|
</Popconfirm>
|
|
</span>
|
|
: <a onClick={() => this.edit(record.key)}>Edit</a>
|
|
}
|
|
</div>
|
|
);
|
|
},
|
|
}];
|
|
this.state = { data };
|
|
this.cacheData = data.map(item => ({ ...item }));
|
|
}
|
|
renderColumns(text, record, column) {
|
|
return (
|
|
<EditableCell
|
|
editable={record.editable}
|
|
value={text}
|
|
onChange={value => this.handleChange(value, record.key, column)}
|
|
/>
|
|
);
|
|
}
|
|
handleChange(value, key, column) {
|
|
const newData = [...this.state.data];
|
|
const target = newData.filter(item => key === item.key)[0];
|
|
if (target) {
|
|
target[column] = value;
|
|
this.setState({ data: newData });
|
|
}
|
|
}
|
|
edit(key) {
|
|
const newData = [...this.state.data];
|
|
const target = newData.filter(item => key === item.key)[0];
|
|
if (target) {
|
|
target.editable = true;
|
|
this.setState({ data: newData });
|
|
}
|
|
}
|
|
save(key) {
|
|
const newData = [...this.state.data];
|
|
const target = newData.filter(item => key === item.key)[0];
|
|
if (target) {
|
|
delete target.editable;
|
|
this.setState({ data: newData });
|
|
this.cacheData = newData.map(item => ({ ...item }));
|
|
}
|
|
}
|
|
cancel(key) {
|
|
const newData = [...this.state.data];
|
|
const target = newData.filter(item => key === item.key)[0];
|
|
if (target) {
|
|
Object.assign(target, this.cacheData.filter(item => key === item.key)[0]);
|
|
delete target.editable;
|
|
this.setState({ data: newData });
|
|
}
|
|
}
|
|
render() {
|
|
return <Table bordered dataSource={this.state.data} columns={this.columns} />;
|
|
}
|
|
}
|
|
|
|
ReactDOM.render(<EditableTable />, mountNode);
|
|
````
|
|
|
|
````css
|
|
.editable-row-operations a {
|
|
margin-right: 8px;
|
|
}
|
|
````
|