【发布时间】:2020-01-31 01:18:30
【问题描述】:
使用Formik 和Ant Design,这是一个简单的设置。
您可以在此处看到粘贴的整个代码:
import React from "react";
import ReactDOM from "react-dom";
import "./styles.css";
import { Formik } from "formik";
import { Form, Input, InputNumber } from "antd";
function App() {
const name = "name";
const count = "count";
return (
<div className="App">
<h1>Formik Testing</h1>
<Formik
initialValues={{ count: 32, name: "sd" }}
validate={async values => {
console.log("Validate", values);
return {
count: `Value ${values.count} is not valid.`
};
}}
onSubmit={(values, actions) => {
console.log(values);
}}
render={props => {
return (
<div>
<Form>
<Form.Item help={props.errors && props.errors[name]}>
<Input
id={name}
name={name}
type={"text"}
onChange={v => {
console.log("Text change ", v);
props.handleChange(v);
}}
onBlur={props.handleBlur}
defaultValue={props.initialValues[name]}
placeholder="Name"
/>
</Form.Item>
<Form.Item help={props.errors && props.errors[count]}>
<InputNumber
id={count}
name={count}
type={"number"}
onChange={v => {
console.log("Number change ", v);
props.handleChange(v);
}}
onBlur={props.handleBlur}
defaultValue={props.initialValues[count]}
placeholder="Count"
/>
</Form.Item>
</Form>
</div>
);
}}
/>
</div>
);
}
const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);
所以基本上:
-
handleChange被InputNumber组件正确调用 - 验证不在数字字段更改时触发
- 文本字段更改时触发验证
-
onblur时使用默认值触发验证(点击离开输入数字字段后)
这似乎是一个错误,但我认为我做错了什么。
感谢任何帮助。
实际代码:
https://codesandbox.io/s/gallant-architecture-0c8p2
(预览 css 似乎有一个错误 - 如果您看到多个箭头,请仅使用顶部的箭头)
【问题讨论】:
标签: javascript reactjs antd formik