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

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>
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值