我是新来的反应者,我试图在antd的模态中渲染表单,但是我的handeChange无法正常工作。 如果我将所有内容都写在模态中,则通常可以正常工作,但是我想知道如何使用不同的组件并使用formik
const InnerForm=({
submitted,
loading,
errors,
handleSubmit,
handleChange,
values,
modalCancel
})=>
(
<Form className="form" onSubmit={handleSubmit}>
<FormItem>
<Input prefix={<Icon type="user" style={{ color: 'rgba(0,0,0,.25)' }} />}
placeholder="email"
onChange={handleChange}
name={"email"}
/>
</FormItem>
<FormItem>
<Input prefix={<Icon type="lock" style={{ color: 'rgba(0,0,0,.25)' }} />}
type="password"
placeholder="Password"
onChange={handleChange}
name={"password"}
/>
</FormItem>
<FormItem>
<Button className={'button_margin'} onClick={modalCancel} type={"primary"}><Icon type="left"/>Go back</Button>
<Button className={'button_margin'} type={"primary"}>Submit</Button>
</FormItem>
</Form>
);
class App extends Component{
constructor(props) {
super(props);
this.state = {
is_authenticated: false,
application_status_modal_visible: false,
}
}
handleChange =(event)=>{
const {name,value}=event.target;
this.setState({
[name]: value,
});
console.log("handle change works");
};
handleSubmit=(values)=>{
console.log(values);
};
modalCancel=()=>{
this.setState({application_status_modal_visible:false})
};
render(){
return(
<Modal
title="Login"
visible={application_status_modal_visible}
footer={null}
>
<Formik onSubmit={this.handleSubmit}
handleChange={this.handleChange}
render={formikProps =>
<InnerForm
modelCancel={this.modalCancel}
{...formikProps}
/>
}/>
</Modal>)
}
}
export default connect()(App)
我希望此输出{email:“ abc@gmail.com”,密码:“ 1234567”}
答案 0 :(得分:1)
<Formik>
组件不接受道具handleChange
;它会传递一个名为handleChange
的渲染道具,您可以按自定义方式使用它,就像这样(我没有列出所有其他必需的道具):
<Formik>
({ handleChange }) => (
<input
onChange={
(e) => {
/* custom stuff */
handleChange(e)}
}
/>
)
</Formik>