Antd React Form使用Radio嵌套多个Select和Input的处理

使用Antd React Form使用Radio会遇到嵌套多个Select和Input的处理,需要多层嵌套和处理默认事件和冒泡,具体实现过程直接上代码。

实现效果布局如下图

代码

<Form
    name="basic"
    form={form}
    labelWrap
    {...formItemLayoutSpan(5, 19)}
    onFinish={onFinish}
    autoComplete="off"
    >
    <Row gutter={gutterValue}>
        <Col span={24}>
             <Form.Item name="isConfirm" noStyle>
                <Radio.Group>
                  <Space direction="vertical">
                    <Radio value={1}>
                      <Space wrap>
                        已定级备案,第
                        <span onClick={eventPrevent}>
                          <Form.Item
                            noStyle
                            shouldUpdate={(prevValues, currentValues) =>
                              (prevValues as any)?.isConfirm !==
                              (currentValues as any)?.isConfirm
                            }
                          >
                            {({ getFieldValue }) => (
                              <FormItemSelect
                                className="level-select"
                                noStyle={true}
                                options={
                                  confidentialLevelNumberDict as optionsDict[]
                                }
                                disabled={g
### 如何使用 JavaScript 获取 HTML 表单的所有字段及其对应的值 在 JavaScript 中,可以通过多种方式获取 HTML 表单中的所有字段以及它们的值。以下是几种常见的实现方法: #### 方法一:使用 `FormData` 对象 `FormData` 是一种内置对象,可以轻松地从 `<form>` 元素中提取键值对[^1]。它仅支持标准的表单控件(如文本框、下拉菜单),还能够处理文件上传。 ```javascript const formElement = document.querySelector('form'); const formData = new FormData(formElement); // 将 FormData 转换为普通对象 let dataObject = {}; for (let [key, value] of formData.entries()) { dataObject[key] = value; } console.log(dataObject); ``` 这种方法适用于大多数场景,并能自动处理多选框等复杂情况。 --- #### 方法二:手动遍历表单元素 如果需要更灵活的操作或者兼容旧版浏览器,则可以选择手动遍历表单内的所有输入元素并收集其值[^3]。 ```javascript function getFormValues(formId) { const form = document.getElementById(formId); const inputs = form.querySelectorAll('input, select, textarea'); let result = {}; Array.from(inputs).forEach(input => { if (input.type === 'radio' || input.type === 'checkbox') { if (input.checked) { // 只记录被选中的选项 result[input.name] = input.value; } } else { result[input.name] = input.value; // 处理其他类型的输入 } }); return result; } console.log(getFormValues('myForm')); ``` 上述代码特别注意了单选按钮 (`radio`) 复选框 (`checkbox`) 的特殊逻辑。 --- #### 方法三:基于框架的方法(例如 Ant Design) 对于现代前端项目,尤其是使用 React 配合组件库(如 Ant Design)的情况下,可以直接利用框架提供的 API 来获取表单数据[^2]。例如,在 Ant Design v4 中,可以通过 `useForm` 或者 Refs 提供的功能来访问表单状态。 ```javascript import { Form, Button } from 'antd'; const MyComponent = () => { const [form] = Form.useForm(); const handleSubmit = () => { console.log(form.getFieldsValue()); // 批量获取所有字段值 }; return ( <> <Form form={form}> {/* 定义表单项 */} </Form> <Button onClick={handleSubmit}>Submit</Button> </> ); }; ``` 这种方式更加简洁高效,尤其适合复杂的动态表单设计。 --- #### 方法四:处理嵌套数组字段 当遇到包含数组或其他复杂结构的表单时,需额外关注字段命名规则以确保正确解析[^4]。比如,假设存在一组可增删的子项,通常会采用类似 `columns[k][field_name]` 这样的名称模式存储数据。 ```html <input name="columns[0][name]" /> <input name="columns[0][age]" /> <input name="columns[1][name]" /> <input name="columns[1][age]" /> ``` 此时可通过正则表达式匹配或自定义解析器完成转换操作。 --- ### 总结 以上介绍了四种同的技术路径用于捕获 HTML 表单的内容,具体选择取决于实际需求技术栈背景。无论是原生 DOM 操作还是依赖第三方工具包,都应充分考虑用户体验与性能优化之间的平衡。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值