--- order: 24 title: en-US: Editable Rows zh-CN: 可编辑行 --- ## zh-CN 带行编辑功能的表格。 ## en-US Table with editable rows. ```tsx import { Table, Input, InputNumber, Popconfirm, Form } from 'antd'; interface Item { key: string; name: string; age: number; address: string; } const originData: Item[] = []; for (let i = 0; i < 100; i++) { originData.push({ key: i.toString(), name: `Edrward ${i}`, age: 32, address: `London Park no. ${i}`, }); } interface EditableCellProps { editing: boolean; dataIndex: string; title: React.ReactNode; inputType: 'number' | 'text'; record: Item; index: number; children: React.ReactNode; } const EditableCell: React.FC = ({ editing, dataIndex, title, inputType, record, index, children, ...restProps }) => { const inputNode = inputType === 'number' ? : ; return ( {editing ? ( {inputNode} ) : ( children )} ); }; const EditableTable = () => { const [form] = Form.useForm(); const [data, setData] = React.useState(originData); const [editingKey, setEditingKey] = React.useState(''); const isEditing = record => record.key === editingKey; const edit = record => { form.setFieldsValue({ ...record }); setEditingKey(record.key); }; const cancel = () => { setEditingKey(''); }; const save = async key => { try { const row = await form.validateFields(); const newData = [...data]; const index = newData.findIndex(item => key === item.key); if (index > -1) { const item = newData[index]; newData.splice(index, 1, { ...item, ...row, }); setData(newData); setEditingKey(''); } else { newData.push(row); setData(newData); setEditingKey(''); } } catch (errInfo) { console.log('Validate Failed:', errInfo); return; } }; const columns = [ { title: 'name', dataIndex: 'name', width: '25%', editable: true, }, { title: 'age', dataIndex: 'age', width: '15%', editable: true, }, { title: 'address', dataIndex: 'address', width: '40%', editable: true, }, { title: 'operation', dataIndex: 'operation', render: (text, record) => { const editable = isEditing(record); return editable ? ( save(record.key)} style={{ marginRight: 8 }}> Save cancel(record.key)}> Cancel ) : ( edit(record)}> Edit ); }, }, ]; const components = { body: { cell: EditableCell, }, }; const mergedColumns = columns.map(col => { if (!col.editable) { return col; } return { ...col, onCell: record => ({ record, inputType: col.dataIndex === 'age' ? 'number' : 'text', dataIndex: col.dataIndex, title: col.title, editing: isEditing(record), }), }; }); return (
); }; ReactDOM.render(, mountNode); ``` ```css .editable-row .ant-form-explain { position: absolute; font-size: 12px; margin-top: -4px; } ```