在antd Table中插入可編輯的單元格實例
最近遇到一個需求,要求表格中某一屬性是可以手動改變的。看了antd Table 的官方組件,發(fā)現(xiàn)不太靈活,所以自己動手寫了一下。
實現(xiàn)的思路大同小異,在columns中插入Input,很簡單的,直接render中返回就好,只是中間遇到小插曲,改變一個input的值所有的都跟著改變,原來是都定義成了同一個變量,后來家里一個動態(tài)的后綴。具體代碼見貼圖

補充知識:React+Ant Design實現(xiàn)可編輯單元格、添加行并利用form獲取新增數(shù)據(jù)
實現(xiàn)如下圖所示需求:

實現(xiàn)功能說明:
點擊添加按鈕,在表格中添加新的空白行(如下圖所示),在點擊提交的時候獲取空白行的數(shù)據(jù)

在構造函數(shù)內定義:
constructor(props) {
super(props)
this.state = {
dataSource:[{
key: 0,
name1: '',
name2: '',
name3: '',
}],//應用信息化查詢方法
count:1,//總數(shù)
}
}
注:如果dataSource定義為空數(shù)組,則頁面初始化時表格沒有輸入框,需要點擊添加行,如下圖

在render()中定義:
const { form: { getFieldDecorator },dataSource } = this.props
在return中添加如下代碼:
<div>
</Form>
<Form.Item>
<Table
columns={[
{ title: '名稱1', dataIndex: 'name1',render: (text, record, index) =>
<Form.Item key={index}>
{getFieldDecorator(`tableDt[${index}].name1`)(
<Input placeholder="請輸入名稱1" />
)}
</Form.Item>
},
{ title: '名稱2', dataIndex: 'name2',render: (text, record, index) =>
<Form.Item key={index}>
{getFieldDecorator(`tableDt[${index}].name2`)(
<Input placeholder="請輸入名稱2" />
)}
</Form.Item>
},
{ title: '名稱3', dataIndex: 'name3',render: (text, record, index) =>
<Form.Item key={index}>
{getFieldDecorator(`tableDt[${index}].name3`)(
<Input placeholder="請輸入名稱3" />
)}
</Form.Item>
},
]}
dataSource={this.state.dataSource}
pagination={false}
/>
</Form.Item>
</Form>
<Row gutter={16}>
<Col span={24}>
<Button onClick={ this.save } type="primary">提交</Button>
<Button onClick={ this.toback }>返回</Button>
<span className="tips">{this.state.saveTipCont}</span>
</Col>
</Row>
</div>
點擊添加行按鈕的操作方法:
//添加應用信息化查詢方法行
handleRowAdd = () => {
const { count, dataSource } = this.state;
const newData = {
key: count,
name1: '',
name2: '',
name3: '',
};
this.setState({
dataSource: [...dataSource, newData],
count: count + 1,
});
}
點擊提交操作的方法:
//保存
save = () => {
//處理校驗值
this.props.form.validateFields((err, values) => {
// console.log(values)
if(!err){
// values.tableDt就是個表格數(shù)據(jù)的數(shù)組,可對獲取的值進行處理校驗處理
}
})
}
實現(xiàn)效果如下:

value.tableDt值如下:

以上這篇在antd Table中插入可編輯的單元格實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
大前端代碼重構之事件攔截iOS?Flutter?Vue示例分析
這篇文章主要為大家介紹了大前端代碼重構之事件攔截iOS?Flutter?Vue示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04
vue3基于elementplus 簡單實現(xiàn)表格二次封裝過程
公司渲染表格數(shù)據(jù)時需要將空數(shù)據(jù)顯示‘-’,并且對于每一列數(shù)據(jù)的顯示也有一定的要求,基于這個需求對element-plus簡單進行了二次封裝,這篇文章主要介紹了vue3基于elementplus 簡單實現(xiàn)表格二次封裝過程,需要的朋友可以參考下2024-05-05
詳解vue-cli中的ESlint配置文件eslintrc.js
本篇文章主要介紹了vue-cli中的ESlint配置文件eslintrc.js詳解 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09

