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

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

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

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

在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>
點(diǎn)擊添加行按鈕的操作方法:
//添加應(yīng)用信息化查詢方法行
handleRowAdd = () => {
const { count, dataSource } = this.state;
const newData = {
key: count,
name1: '',
name2: '',
name3: '',
};
this.setState({
dataSource: [...dataSource, newData],
count: count + 1,
});
}
點(diǎn)擊提交操作的方法:
//保存
save = () => {
//處理校驗(yàn)值
this.props.form.validateFields((err, values) => {
// console.log(values)
if(!err){
// values.tableDt就是個表格數(shù)據(jù)的數(shù)組,可對獲取的值進(jìn)行處理校驗(yàn)處理
}
})
}
實(shí)現(xiàn)效果如下:

value.tableDt值如下:

以上這篇在antd Table中插入可編輯的單元格實(shí)例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue項(xiàng)目之?dāng)?shù)量占比進(jìn)度條實(shí)現(xiàn)方式
這篇文章主要介紹了vue項(xiàng)目之?dāng)?shù)量占比進(jìn)度條實(shí)現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12
vue-baidu-map 進(jìn)入頁面自動定位的解決方案(推薦)
這篇文章主要介紹了vue-baidu-map 進(jìn)入頁面自動定位的解決方案,需要的朋友可以參考下2018-04-04
Vue實(shí)現(xiàn)動態(tài)顯示表單項(xiàng)填寫進(jìn)度功能
這篇文章主要介紹了Vue實(shí)現(xiàn)動態(tài)顯示表單項(xiàng)填寫進(jìn)度功能,此功能可以幫助用戶了解表單填寫的進(jìn)度和當(dāng)前狀態(tài),提高用戶體驗(yàn),通常實(shí)現(xiàn)的方式是在表單中添加進(jìn)度條,根據(jù)用戶填寫狀態(tài)動態(tài)更新進(jìn)度條,感興趣的同學(xué)可以參考下文2023-05-05
基于Vue3+Element Plus 實(shí)現(xiàn)多表單校驗(yàn)demo
表單校驗(yàn)在日常的開發(fā)需求中是一種很常見的需求,通常在提交表單發(fā)起請求前校驗(yàn)用戶輸入是否符合規(guī)則,通常只需formRef.value.validate()即可校驗(yàn),本文給大家介紹基于Vue3+Element Plus 實(shí)現(xiàn)多表單校驗(yàn)demo,感興趣的朋友一起看看吧2024-06-06
Vue實(shí)現(xiàn)獲取后端接口API代碼片段(已封裝Service方法名)
Vue實(shí)現(xiàn)獲取后端接口API代碼片段(已封裝Service方法名),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07

