《PC端UI框架》Ant Design V4 中的 Modal

本文介绍了一个使用 Ant Design 的 Modal 组件时遇到的问题:Modal 关闭后 Form 表单数据未被清空。文章详细解释了原因,并提供了两种解决方案:一是手动清空表单数据和状态数据;二是利用 Modal 的 destroyOnClose 属性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Modal 中包含表单,Modal 关闭后没有清空 Form 表单的值:

import React from 'react';
import { Modal, Button, Form, Input } from 'antd';

export default class extends React.Component{
  state = {
    isModalVisible: false,
    formDtata: {},
  }
  formRef = React.createRef()

  componentDidMount() {
     // 只初始加载的时候执行一次,由于 React 复用组件,再次点击并不会重新执行此生命周期函数,这也是导致 Modal 关闭后没有清空 Form 表单的值的原因
     console.log('modal componentDidMount')
  }

  showModal = () => {
    // 再次点击打开 Modal,会发现上次输入的表单中的数据仍然存在
    // 打印会发现,this.state.formDtata 中仍然保存着上次表单输入的值
    console.log(this.state.formDtata)
   
    this.setState({isModalVisible: true})
  }
  
  handleOk = async () => {
    let formData = await this.formRef.current.validateFields()
    this.setState({
      formDtata: formData,
      isModalVisible: false,
    })
  }

  render() {
    const {isModalVisible} = this.state
    const layout = {
      labelCol: {
        span: 4,
      },
      wrapperCol: {
        span: 20,
      },
    }
    return (
      <div>
        <Button type="primary" onClick={this.showModal}>打开弹框</Button>
        <Modal title="弹框" visible={isModalVisible}
          footer={
            <Button type="primary" onClick={this.handleOk}>确定</Button>
          }>
          <Form {...layout} ref={this.formRef}>
            <Form.Item label="姓名" name="username"><Input /></Form.Item>
            <Form.Item label="密码" name="password"><Input /></Form.Item>
          </Form>
        </Modal>
      </div>
    )
  }
}

解决方法:

  1. 关闭 Modal 时手动清空表单中的数据和 state 中保存的数据。
    handleOk = async () => {
    
        let formData = await this.formRef.current.validateFields()
        this.setState({
          formDtata: formData,
        }, () => {
          this.setState({
            isModalVisible: false,
            formDtata: {}, // 清除 this.state.formDtata 中保存的数据
          })
          this.formRef.current.resetFields() // 清除表单中的数据
        })
      }
    
  2. 给 Modal 设置 destroyOnClose,关闭时销毁 Modal 里的子元素。
    //  state 中保存的数据仍然存在,需要手动清除
    <Modal destroyOnClose={true}></Modal>
    
### 关于 Ant Design Modal 组件的使用 #### 安装与基础配置 为了能够使用 `Ant Design` 的组件库,在项目中首先需要安装对应的包。对于 Vue 项目而言,可以通过如下命令来完成 `ant-design-vue` 的安装[^1]: ```bash npm install ant-design-vue ``` 接着按照官方文档指引进行必要的框架配置。 #### 基本用法示例 下面是一个简单的例子展示如何创建并显示一个基本对话框: ```html <template> <a-button type="primary" @click="showModal">Open Modal</a-button> <!-- Basic Modal --> <a-modal v-model:visible="visible" title="Basic Modal"> <p>Some contents...</p> </a-modal> </template> <script> export default { data() { return { visible: false, }; }, methods: { showModal() { this.visible = true; } } }; </script> ``` 这段代码展示了通过点击按钮触发模态窗口打开的效果,并设置了模态窗口内的简单文本内容[^4]。 #### 自定义功能增强 除了标准的功能外,还可以对 `Modal` 进行扩展定制化开发,比如实现拖拽效果或是支持全屏操作等功能。这通常涉及到监听特定事件并对这些行为做出响应处理。例如,可以利用第三方插件或自行编写逻辑来满足需求。 #### API 参考 以下是部分常用的属性列表(更多详情参见官方API文档): | 参数 | 类型 | 默认值 | 描述 | | --- | --- | --- | --- | | visible | boolean | - | 控制modal显隐状态| | title | string \| slot | '' | 对话框标题 | | okText | string | 'Ok' | 确认按钮文字 | | cancelText | string | 'Cancel'|取消按钮文字| 此外还有许多其他选项可用于进一步调整样式和交互方式,具体可见官方提供的完整版面说明文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值