react antd 表单提交完成需要清空关闭组件
时间: 2023-07-29 22:14:51 浏览: 129
好的,针对你的问题,我可以给出以下的解决方案:
1. 在表单提交成功后,执行清空表单操作,并将弹窗组件关闭。
2. 可以通过在父组件中维护一个状态变量,控制弹窗组件的显示和隐藏。表单提交成功后,将该状态变量设置为 false,即可关闭弹窗组件。
具体的实现方式,可以参考以下代码:
```jsx
import React, { useState } from 'react';
import { Modal, Form, Input, Button } from 'antd';
const ExampleForm = (props) => {
const [form] = Form.useForm();
const [visible, setVisible] = useState(false);
const handleSubmit = () => {
form.validateFields().then((values) => {
// 提交表单
console.log(values);
// 清空表单
form.resetFields();
// 关闭弹窗组件
setVisible(false);
});
};
return (
<>
<Button onClick={() => setVisible(true)}>打开弹窗</Button>
<Modal
title="示例弹窗"
visible={visible}
onCancel={() => setVisible(false)}
footer={[
<Button key="cancel" onClick={() => setVisible(false)}>
取消
</Button>,
<Button key="submit" type="primary" onClick={handleSubmit}>
提交
</Button>,
]}
>
<Form form={form}>
<Form.Item
label="姓名"
name="name"
rules={[{ required: true, message: '请输入姓名' }]}
>
<Input />
</Form.Item>
<Form.Item
label="邮箱"
name="email"
rules={[{ required: true, message: '请输入邮箱' }]}
>
<Input />
</Form.Item>
</Form>
</Modal>
</>
);
};
export default ExampleForm;
```
在上述代码中,我们使用了 `useState` 钩子来维护弹窗组件的状态变量 `visible`,并在表单提交成功后将其设置为 false,以关闭弹窗组件。同时,我们也使用了 `Form` 组件来进行表单的管理,通过 `form.resetFields()` 方法来清空表单。在弹窗组件的底部,我们添加了取消和提交按钮,点击提交按钮时,会调用 `handleSubmit` 函数来提交表单。
阅读全文