and*_*ras 3 javascript reactjs antd formik
使用Formikwith 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);
Run Code Online (Sandbox Code Playgroud)
所以基本上:
handleChange被InputNumber组件正确调用onblur(单击离开输入数字字段后)时,使用默认值触发验证这似乎是一个错误,但我认为我做错了什么。
任何帮助表示赞赏。
代码在行动:
https://codesandbox.io/s/gallant-architecture-0c8p2
(预览 css 似乎有一个错误 - 如果您看到多个箭头,请仅使用最上面的一个)
您可以使用 Formik 的内置setFieldValue函数为输入定义自己的更改处理程序,这将直接设置数字值:
<InputNumber
id={count}
name={count}
type={"number"}
onChange={v => {
props.setFieldValue(count, v);
}}
onBlur={props.handleBlur}
defaultValue={props.initialValues[count]}
placeholder="Count"
/>
Run Code Online (Sandbox Code Playgroud)
根据文档,它还具有第三个布尔参数来确定是否运行验证。因此,如果在主要组件上启用,则传入trueafterv应触发验证。validateOnChangeFormik
| 归档时间: |
|
| 查看次数: |
10686 次 |
| 最近记录: |