antd4.0模态框获取form表单的提交数据内容

antd4.0模态框获取form表单的提交数据内容

要想那到值,其实和antd4版本以前拿数据是差不多的。

因为antd3以前拿数据(有段时间不用3版本了,只记得大概,简要写一下,不一定就没错):
const { getFieldDecorator } = this.props.form;

onOkHandler = () => {
// 3版本拿antd中表单的数据
	this.props.form.validateFields((err, values) => {
	      if(!err){
	        console.log(values);//这里可以拿到数据
	      }
    });
}
const { getFieldDecorator } = this.props.form;
<Form className="login-form">
        <FormItem>
          {getFieldDecorator('userName', {
            rules: [{ required: true, message: 'Please input your username!' }],
          })(
            <Input prefix={<Icon type="user" style={{ color: 'rgba(0,0,0,.25)' }} />} placeholder="Username" />
          )}
        </FormItem>
        <FormItem>
          {getFieldDecorator('password', {
            rules: [{ required: true, message: 'Please input your Password!' }],
          })(
            <Input prefix={<Icon type="lock" style={{ color: 'rgba(0,0,0,.25)' }} />} type="password" placeholder="Password" />
          )}
        </FormItem>
      </Form>

antd4版本:

import { Modal, Form } form "antd";
	const Index = props => {
		const [form] = Form.useForm();
	const handleOk = (e) => {//点击对话框OK按钮触发的事件
		console.log(form);
		// 获取form的值
		console.log(form.getFieldsValue());
		form.getFieldsValue();
	}
	return <>
	<Modal
        title={props.isEditUser ?
            "编辑用户" :
            "新建用户"}
        visible={props.createUserModalVisible}
        destroyOnClose={true}
        onCancel={onCancel}
        onOk={onOk}
        okText={"保存"}
    >
        <Form
        **// 要有form属性,也方便清空表单内的**
            form={form}
            name={"createUserModal"}
            {...formItemLayout}
            className={"normalForm"}
        >
            <FormItem label={"用户名"} name={"userName"} rules={[
                {
                    required: true,
                    message: "请输入用户名"
                }
            ]} colon={false}>
                <Input/>
            </FormItem>
            <FormItem label={"手机号"} name={"phone"} rules={[
                {
                    required: true,
                    message: "请输入手机号"
                }
            ]} colon={false}>
                <Input/>
            </FormItem>
            <FormItem label={"邮箱"} name={"email"} rules={[
                {
                    required: true,
                    message: "请输入邮箱"
                }
            ]} colon={false}>
                <Input/>
            </FormItem>
            <FormItem label={"姓名"} colon={false} name={"fullName"}>
                <Input/>
            </FormItem>
            <FormItem label={"角色"} colon={false} name={"js"} rules={[
                {
                    required: true,
                    message: "请选择角色"
                }
            ]}>
                <Select suffixIcon={<Icon type={"icongeneraliconyiru"}/>}>
                    <Option value={"老师"}>老师</Option>
                    <Option value={"学生"}>学生</Option>
                </Select>
            </FormItem>
            <FormItem label={"学/工号"} colon={false} name={"num"}>
                <Input/>
            </FormItem>
            <FormItem label={"组织架构"} colon={false} name={"org"}>
                <Select suffixIcon={<Icon type={"icongeneraliconyiru"}/>}>
                    <Option value={"11"}>11</Option>
                    <Option value={"22"}>22</Option>
                </Select>
            </FormItem>
        </Form>
    </Modal>;
</>
}
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值