antd 父组件获取子组件中form表单的值

子组件

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

const FormItem = Form.Item;

class Forms extends Component{
    getItemsValue = ()=>{    //3、自定义方法,用来传递数据(需要在父组件中调用获取数据)
        const valus= this.props.form.getFieldsValue();       //4、getFieldsValue:获取一组输入控件的值,如不传入参数,则获取全部组件的值
        return valus;
    }
    render(){
        const { form } = this.props;
        const { getFieldDecorator } = form;    //1、将getFieldDecorator 解构出来,用于和表单进行双向绑定
        return(
            <>
                <Form layout="vertical">
                    <FormItem label="姓名">
                        {getFieldDecorator('name')(    //2、getFieldDecorator 的使用方法,这种写法真的很蛋疼
                            <Input />
                        )}
                    </FormItem>
                    <FormItem label="年龄">
                        {getFieldDecorator('age')(
                            <Input />
                        )}
                    </FormItem>
                    <FormItem label="城市">
                        {getFieldDecorator('address')(
                            <Input />
                        )}
                    </FormItem>
                </Form>
            </>
        )
    }
}

export default Form.create()(Forms);        //创建form实例

 父组件

import React, { Component } from 'react';
import { Modal } from 'antd';
import Forms from './Forms'

export default class Modals extends Component {
    handleCancel = () => {
        this.props.closeModal(false);
    }
    handleCreate = () => {
        console.log(this.formRef.getItemsValue());     //6、调用子组件的自定义方法getItemsValue。注意:通过this.formRef 才能拿到数据
        this.props.getFormRef(this.formRef.getItemsValue());
        this.props.closeModal(false);
    }
    render() {
        const { visible } = this.props;
        return (
            <Modal
                visible={visible}
                title="新增"
                okText="保存"
                onCancel={this.handleCancel}
                onOk={this.handleCreate}
            >
            <Forms
                wrappedComponentRef={(form) => this.formRef = form}       //5、使用wrappedComponentRef 拿到子组件传递过来的ref(官方写法)
            />
            </Modal>
        );
    }
}

 官方文档

class CustomizedForm extends React.Component { ... }

// use wrappedComponentRef
const EnhancedForm = Form.create()(CustomizedForm);
<EnhancedForm wrappedComponentRef={(form) => this.form = form} />
this.form // => The instance of CustomizedForm

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果组件是 Ant Design 的 Form 组件,可以通过以下两种方式进行组件之间的通信: 1. 使用 React 的 Context API 使用 React 的 Context API 可以在组件定义一个 Context,然后在组件使用该 Context,从而实现组件之间的通信。 首先,在组件定义 Context: ```javascript import React, { createContext, useState } from 'react'; import { Form } from 'antd'; export const MyContext = createContext(); const ParentComponent = () => { const [form] = Form.useForm(); const [data, setData] = useState({}); const onFinish = (values) => { setData(values); }; return ( <MyContext.Provider value={{ data, form }}> <Form form={form} onFinish={onFinish}> {/* 组件 */} </Form> </MyContext.Provider> ); }; export default ParentComponent; ``` 然后,在组件使用该 Context: ```javascript import React, { useContext } from 'react'; import { MyContext } from './ParentComponent'; const ChildComponent = () => { const { data, form } = useContext(MyContext); return ( <div> <p>{data.name}</p> <Form.Item label="Name" name="name"> <Input /> </Form.Item> </div> ); }; export default ChildComponent; ``` 2. 将组件作为函数组件传递给组件组件作为函数组件传递给组件,可以在组件通过 props 获取组件传递的 Form 实例,从而实现组件之间的通信。 首先,在组件Form 实例传递给组件: ```javascript import React, { useState } from 'react'; import { Form } from 'antd'; import ChildComponent from './ChildComponent'; const ParentComponent = () => { const [form] = Form.useForm(); const [data, setData] = useState({}); const onFinish = (values) => { setData(values); }; return ( <Form form={form} onFinish={onFinish}> <ChildComponent form={form} data={data} /> </Form> ); }; export default ParentComponent; ``` 然后,在组件通过 props 获取 Form 实例: ```javascript import React from 'react'; import { Form, Input } from 'antd'; const ChildComponent = ({ form, data }) => { return ( <div> <p>{data.name}</p> <Form.Item label="Name" name="name"> <Input /> </Form.Item> </div> ); }; export default ChildComponent; ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值