在antd Table中插入可編輯的單元格實(shí)例
最近遇到一個(gè)需求,要求表格中某一屬性是可以手動(dòng)改變的。看了antd Table 的官方組件,發(fā)現(xiàn)不太靈活,所以自己動(dòng)手寫(xiě)了一下。
實(shí)現(xiàn)的思路大同小異,在columns中插入Input,很簡(jiǎn)單的,直接render中返回就好,只是中間遇到小插曲,改變一個(gè)input的值所有的都跟著改變,原來(lái)是都定義成了同一個(gè)變量,后來(lái)家里一個(gè)動(dòng)態(tài)的后綴。具體代碼見(jiàn)貼圖
補(bǔ)充知識(shí):React+Ant Design實(shí)現(xiàn)可編輯單元格、添加行并利用form獲取新增數(shù)據(jù)
實(shí)現(xiàn)如下圖所示需求:
實(shí)現(xiàn)功能說(shuō)明:
點(diǎn)擊添加按鈕,在表格中添加新的空白行(如下圖所示),在點(diǎn)擊提交的時(shí)候獲取空白行的數(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ù)組,則頁(yè)面初始化時(shí)表格沒(méi)有輸入框,需要點(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="請(qǐng)輸入名稱1" /> )} </Form.Item> }, { title: '名稱2', dataIndex: 'name2',render: (text, record, index) => <Form.Item key={index}> {getFieldDecorator(`tableDt[${index}].name2`)( <Input placeholder="請(qǐng)輸入名稱2" /> )} </Form.Item> }, { title: '名稱3', dataIndex: 'name3',render: (text, record, index) => <Form.Item key={index}> {getFieldDecorator(`tableDt[${index}].name3`)( <Input placeholder="請(qǐng)輸入名稱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就是個(gè)表格數(shù)據(jù)的數(shù)組,可對(duì)獲取的值進(jìn)行處理校驗(yàn)處理 } }) }
實(shí)現(xiàn)效果如下:
value.tableDt值如下:
以上這篇在antd Table中插入可編輯的單元格實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue @input和@click的區(qū)別及說(shuō)明
這篇文章主要介紹了vue @input和@click的區(qū)別及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10vue項(xiàng)目之?dāng)?shù)量占比進(jìn)度條實(shí)現(xiàn)方式
這篇文章主要介紹了vue項(xiàng)目之?dāng)?shù)量占比進(jìn)度條實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12vue-baidu-map 進(jìn)入頁(yè)面自動(dòng)定位的解決方案(推薦)
這篇文章主要介紹了vue-baidu-map 進(jìn)入頁(yè)面自動(dòng)定位的解決方案,需要的朋友可以參考下2018-04-04Vue實(shí)現(xiàn)動(dòng)態(tài)顯示表單項(xiàng)填寫(xiě)進(jìn)度功能
這篇文章主要介紹了Vue實(shí)現(xiàn)動(dòng)態(tài)顯示表單項(xiàng)填寫(xiě)進(jìn)度功能,此功能可以幫助用戶了解表單填寫(xiě)的進(jìn)度和當(dāng)前狀態(tài),提高用戶體驗(yàn),通常實(shí)現(xiàn)的方式是在表單中添加進(jìn)度條,根據(jù)用戶填寫(xiě)狀態(tài)動(dòng)態(tài)更新進(jìn)度條,感興趣的同學(xué)可以參考下文2023-05-05基于Vue3+Element Plus 實(shí)現(xiàn)多表單校驗(yàn)demo
表單校驗(yàn)在日常的開(kāi)發(fā)需求中是一種很常見(jiàn)的需求,通常在提交表單發(fā)起請(qǐng)求前校驗(yàn)用戶輸入是否符合規(guī)則,通常只需formRef.value.validate()即可校驗(yàn),本文給大家介紹基于Vue3+Element Plus 實(shí)現(xiàn)多表單校驗(yàn)demo,感興趣的朋友一起看看吧2024-06-06vue如何解決循環(huán)引用組件報(bào)錯(cuò)的問(wèn)題
這篇文章主要介紹了vue如何解決循環(huán)引用組件報(bào)錯(cuò)的問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09Vue實(shí)現(xiàn)獲取后端接口API代碼片段(已封裝Service方法名)
Vue實(shí)現(xiàn)獲取后端接口API代碼片段(已封裝Service方法名),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07