網(wǎng)站首頁 編程語言 正文
本文實例為大家分享了react實現(xiàn)動態(tài)表單的具體代碼,供大家參考,具體內(nèi)容如下
1.小要求
在工作中,我們也會碰到這樣子的需求:在填寫信息的時候,可以填寫多個人名、多個需求、以及動態(tài)生產(chǎn)一個分組。
今天我們就以: 可以動態(tài)的添加/刪除人名、路徑以及可以添加/刪除一個分組的需求來開始今天的學(xué)習(xí)之旅。需求如下圖所示:
2.技術(shù)點分析
1.數(shù)據(jù)結(jié)構(gòu)
2.react+antd 動態(tài)編輯表格數(shù)據(jù)提及的知識點
3.js操作數(shù)據(jù)的方法: 添加數(shù)據(jù)、根據(jù)下標(biāo)刪除數(shù)據(jù)
3.代碼分析
3.1 數(shù)據(jù)結(jié)構(gòu)分析
/**
*?? ?1. 最外面是一個數(shù)組
*?? ?2. 中間是一個字典,每個字典就是一個分組
*?? ?3. name表示人名,也是一個數(shù)組,這樣子我們就可以動態(tài)的添加/刪除人名(path路徑,跟name同理)
**/
const [data, setData] = useState([
? ? ? ? {
? ? ? ? ? ? 'name': [''],
? ? ? ? ? ? 'path': ['']
? ? ? ? }
?])
3.2添加人名分析
添加路徑和添加人名的代碼類似,就不重復(fù)編寫了,大家可以去看完整的代碼。這里也“添加人名”舉例子:
<Button type="dashed" width={200} onClick={() => {
??? ??? ?// 采用了[...xxx]性質(zhì),在對應(yīng)分組中名字?jǐn)?shù)據(jù)中添加一個空的數(shù)據(jù)
? ? ? ?let obj = [...data]
? ? ? ?setData([])
? ? ? ?obj[index]['name'].push('')
? ? ? ?// 然后在更新數(shù)據(jù)
? ? ? ?setData(obj);
? ?}}>+添加人名</Button>
3.3修改人名分析
修改路徑和修改人名的代碼類似,就不重復(fù)編寫了,大家可以去看完整的代碼。這里也“修改人名”舉例子:
<Input style={{ width: 200, marginLeft: 10 }} value={nameItem} onChange={(e) => {
?? ? ?// 采用了[...xxx]性質(zhì),
? ? ? let obj = [...data]
? ? ? setData([])
? ? ? // 修改對應(yīng)的人名
? ? ? obj[index]['name'][nameIndex] = e.target.value
? ? ? // 然后在更新數(shù)據(jù)
? ? ? setData(obj)
? }} />
3.4刪除人名分析
刪除路徑和刪除人名的代碼類似,就不重復(fù)編寫了,大家可以去看完整的代碼。這里也“刪除人名”舉例子:
<MinusCircleOutlined style={{ marginTop: 10, marginLeft: 5, display: item.name.length == 1 ? 'none' : '' }} onClick={() => {
?? ?// 采用了[...xxx]性質(zhì),
? ? let obj = [...data]
? ? setData([])
? ? // 刪除人名,使用js的數(shù)組用法: 根據(jù)下標(biāo)刪除
? ? obj[index]['name'].splice(nameIndex, 1);
? ? setData(obj)
}} />
3.5添加分組?
<Button type="dashed" style={{width:'400px',}} onClick={()=>{
??? ? ?// 采用了[...xxx]性質(zhì),
? ? ? let obj = [...data]
? ? ? setData([])
? ? ? // 在原來的數(shù)組中,在添加一個對象
? ? ? obj.push({
? ? ? ? ? 'name':[''],
? ? ? ? ? 'path':['']
? ? ? })
? ? ? setData(obj);
? ?}}>+分組</Button>
3.6刪除分組
<MinusCircleOutlined style={{ marginTop: 5, marginLeft: 8, display: data.length == 1 ? 'none' : '' }} onClick={() => {
? ? let flag = 0
? ? ?// 判斷名字/路徑的輸入框中是否有值
? ? ?data[index]['name'].map(item=>{
? ? ? ? ?if(item != ''){
? ? ? ? ? ? ?flag = 1
? ? ? ? ?}
? ? ?})
? ? ?if(flag == 0){
? ? ? ? ?data[index]['path'].map(item=>{
? ? ? ? ? ? ?if(item != ''){
? ? ? ? ? ? ? ? ?flag = 1
? ? ? ? ? ? ?}
? ? ? ? ?})
? ? ?}
?? ? // 如果有值的話,則出現(xiàn)一個彈框提示用戶這里還是有值的,是否要刪除
? ? ?if(flag){
? ? ? ? ?confirm({
? ? ? ? ? ? ?title: '已經(jīng)編輯了部分?jǐn)?shù)據(jù),確認(rèn)要刪除',
? ? ? ? ? ? ?icon: <ExclamationCircleOutlined />,
? ? ? ? ? ? ?centered:'true',
? ? ? ? ? ? ?okText:'確認(rèn)',
? ? ? ? ? ? ?cancelText:'取消',
? ? ? ? ? ? ?onOk() {
? ? ? ? ? ? ? ? ?let obj = [...data]
? ? ? ? ? ? ? ? ?setData([])
? ? ? ? ? ? ? ? ?obj.splice(index, 1);
? ? ? ? ? ? ? ? ?setData(obj)
? ? ? ? ? ? ?},
? ? ? ? ? ? ?onCancel() {},
? ? ? ? ?});
? ? ?}else{
? ? ? ? ?let obj = [...data]
? ? ? ? ?setData([])
? ? ? ? ?obj.splice(index, 1);
? ? ? ? ?setData(obj)
? ? ?}
? ??
?}} />
4.完整代碼
import React, { useState } from 'react';
import { Input, Row, Col, Button, Divider, Modal } from 'antd'
import { MinusCircleOutlined, ExclamationCircleOutlined } from '@ant-design/icons';
const { confirm } = Modal;
function Index() {
? ? const [data, setData] = useState([
? ? ? ? {
? ? ? ? ? ? 'name': [''],
? ? ? ? ? ? 'path': ['']
? ? ? ? }
? ? ])
? ? return (
? ? ? ? <div style={{ marginLeft: 50, marginTop: 100 }}>
? ? ? ? ? ? <div>
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? data.map((item, index) => {
? ? ? ? ? ? ? ? ? ? ? ? return <div>
? ? ? ? ? ? ? ? ? ? ? ? ? ? <div style={{display:'flex'}}>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <span>第{index + 1}組</span>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <MinusCircleOutlined style={{ marginTop: 5, marginLeft: 8, display: data.length == 1 ? 'none' : '' }} onClick={() => {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? let flag = 0
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? console.log(data[index]['name']);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? data[index]['name'].map(item=>{
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if(item != ''){
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? flag = 1
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? return false
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? })
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if(flag == 0){
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? data[index]['path'].map(item=>{
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if(item != ''){
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? flag = 1
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? return false
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? })
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? if(flag){
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? confirm({
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? title: '已經(jīng)編輯了部分?jǐn)?shù)據(jù),確認(rèn)要刪除',
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? icon: <ExclamationCircleOutlined />,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? centered:'true',
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? okText:'確認(rèn)',
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? cancelText:'取消',
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? onOk() {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? let obj = [...data]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData([])
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? obj.splice(index, 1);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData(obj)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? onCancel() {},
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? });
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }else{
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? let obj = [...data]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData([])
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? obj.splice(index, 1);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData(obj)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }} />
? ? ? ? ? ? ? ? ? ? ? ? ? ? </div>
? ? ? ? ? ? ? ? ? ? ? ? ? ? <Divider />
? ? ? ? ? ? ? ? ? ? ? ? ? ? <Row>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? item.name.map((nameItem, nameIndex) => {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? return <Col span={8}>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <div style={{ display: 'flex', marginTop: 10 }}>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <span >{'姓名' + (nameIndex + 1) + ':'}</span>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <Input style={{ width: 200, marginLeft: 10 }} value={nameItem} onChange={(e) => {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? let obj = [...data]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData([])
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? obj[index]['name'][nameIndex] = e.target.value
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData(obj)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }} />
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <MinusCircleOutlined style={{ marginTop: 10, marginLeft: 5, display: item.name.length == 1 ? 'none' : '' }} onClick={() => {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? let obj = [...data]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData([])
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? obj[index]['name'].splice(nameIndex, 1);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData(obj)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }} />
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? </div>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? </Col>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? })
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? </Row>
? ? ? ? ? ? ? ? ? ? ? ? ? ? <div style={{ display: 'flex', width: '100vw', justifyContent: 'center', marginTop: 10, marginBottom: 10 }}>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <Button type="dashed" width={200} onClick={() => {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? let obj = [...data]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData([])
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? obj[index]['name'].push('')
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData(obj);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }}>+添加人名</Button>
? ? ? ? ? ? ? ? ? ? ? ? ? ? </div>
? ? ? ? ? ? ? ? ? ? ? ? ? ? <Row>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? item.path.map((pathItem, pathIndex) => {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? return <Col span={8}>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <div style={{ display: 'flex', marginTop: 10 }}>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <span >{'路徑' + (pathIndex + 1) + ':'}</span>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <Input style={{ width: 200, marginLeft: 10 }} value={pathItem} onChange={(e) => {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? let obj = [...data]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData([])
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? obj[index]['path'][pathIndex] = e.target.value
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData(obj)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }} />
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <MinusCircleOutlined style={{ marginTop: 10, marginLeft: 5, display: item.path.length == 1 ? 'none' : '' }} onClick={() => {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? let obj = [...data]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData([])
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? obj[index]['path'].splice(pathIndex, 1);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData(obj)
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }} />
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? </div>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? </Col>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? })
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? ? ? ? ? </Row>
? ? ? ? ? ? ? ? ? ? ? ? ? ? <div style={{ display: 'flex', width: '100vw', justifyContent: 'center', marginTop: 10, marginBottom: 10 }}>
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? <Button type="dashed" width={200} onClick={() => {
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? let obj = [...data]
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData([])
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? obj[index]['path'].push('')
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? setData(obj);
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? }}>+添加路徑</Button>
? ? ? ? ? ? ? ? ? ? ? ? ? ? </div>
? ? ? ? ? ? ? ? ? ? ? ? </div>
? ? ? ? ? ? ? ? ? ? })
? ? ? ? ? ? ? ? }
? ? ? ? ? ? </div>
? ? ? ? ? ? <div style={{display:'flex', width:'100vw', justifyContent:'center', marginTop:10, marginBottom:10}}>
? ? ? ? ? ? ? ? <Button type="dashed" style={{width:'400px',}} onClick={()=>{
? ? ? ? ? ? ? ? ? ? let obj = [...data]
? ? ? ? ? ? ? ? ? ? setData([])
? ? ? ? ? ? ? ? ? ? obj.push({
? ? ? ? ? ? ? ? ? ? ? ? 'name':[''],
? ? ? ? ? ? ? ? ? ? ? ? 'path':['']
? ? ? ? ? ? ? ? ? ? })
? ? ? ? ? ? ? ? ? ? setData(obj);
? ? ? ? ? ? ? ? }}>+分組</Button>
? ? ? ? ? ? </div>
? ? ? ? </div>
? ? )
}
export default Index
總結(jié)
好了,今天就分享到這里,希望大家在學(xué)習(xí)了一篇博文之后,可以封裝出自己的組件來應(yīng)對多種多樣的需求。
原文鏈接:https://blog.csdn.net/qq_35905501/article/details/120546664
相關(guān)推薦
- 2022-05-25 Postman動態(tài)獲取值(動態(tài)設(shè)置全局變量)
- 2022-04-24 詳解golang?定時任務(wù)time.Sleep和time.Tick實現(xiàn)結(jié)果比較_Golang
- 2022-12-06 python中isdigit()?isalpha()用于判斷字符串的類型問題_python
- 2022-06-12 淺談Android?Dialog窗口機(jī)制_Android
- 2023-02-18 Framework中實現(xiàn)OC和Swift的混編方案_IOS
- 2022-04-24 C++vector的用法你都知道嘛_C 語言
- 2022-06-18 Elasticsearch之倒排索引及索引操作_python
- 2022-07-29 Ubuntu中的sudo和su命令介紹_linux shell
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支