【问题标题】:How do I validate if a state has been set using Yup validation?如何验证是否已使用 Yup 验证设置状态?
【发布时间】:2021-10-28 08:38:04
【问题描述】:

我正在使用 Yup 检查用户是否选择了一个字段(使用状态“groupSelected”设置)。 (该字段为必填字段)

<Formik initialValues={{title:'', group:{groupSelected}}}
                        enableReinitialize='true'      // since we are setting the formik initial value to state, this is required to update the initial value when state changes
                        onSubmit={values => console.log(values)}
                        validationSchema={validationSchema}

提交表单时,我能够很好地检索选定的值。但是,我不确定如何验证状态是否已实际设置。

    group: Yup.string().required()

我尝试使用上述方法,但我猜它不起作用,因为 groupSelected 不是字符串。

【问题讨论】:

  • 初始值不会在重新渲染时更新。它们只执行一次。这就是它们的目的 - Initial
  • 您的group 字段是&lt;Select/&gt; 吗?

标签: javascript reactjs react-native formik yup


【解决方案1】:

这是Formikyup 的基本示例。 你也可以试试这个方法。

示例:

import React from "react";
import { Formik, Form, Field } from "formik";
import * as Yup from "yup";

const SignupSchema = Yup.object().shape({
  firstName: Yup.string()
    .trim("spaces no t allowed")
    .strict()
    .required("Required"),
});

export const MyForm = () => (
  <div>
    <h1>Signup</h1>
    <Formik
      initialValues={{
        firstName: "",
      }}
      validationSchema={SignupSchema}
      onSubmit={(values) => {
        // same shape as initial values
        console.log(values);
      }}
    >
      {({ errors, values, touched, setFieldValue, registerField }) => (
        <Form>
          <Field 
            name="firstName" 
          />
          {errors.firstName && touched.firstName ? (
            <div>{errors.firstName}</div>
          ) : null}
          <br />
          {JSON.stringify(errors)}
          <button type="submit">Submit</button>
        </Form>
      )}
    </Formik>
  </div>
);

【讨论】:

  • 我已经认识这个伙伴了。我想知道的是如何使用 Yup 来检查状态是否已设置。
  • 您可以console.log(values) 并检查它是否设置了值。
猜你喜欢
  • 1970-01-01
  • 2021-12-20
  • 1970-01-01
  • 2021-10-10
  • 2021-12-21
  • 2018-11-14
  • 2023-02-08
  • 2021-12-27
  • 2019-07-23
相关资源
最近更新 更多