Formik在对象数组中找不到Yup验证错误

问题描述 投票:0回答:1

formik v1.5.2,yup v0.27.0,反应v16.8.6

我无法使用一组对象在Formik中进行Yup验证工作。代码在codesandbox https://codesandbox.io/s/kw1r49v25o?fontsize=14

初始值:

const INITIAL_VALUES = {
  users: [
    {
      value: "admin"
    }
  ]
};

Yup架构:

const usersSchema = Yup.object().shape({
  users: Yup.array().of(
    Yup.object().shape({
      value: Yup.string()
        .max(3)
        .required()
    })
  )
});

我故意将字符串大小限制为3个字符以触发验证错误。

组件:

function App() {
  const [data, setData] = useState(INITIAL_VALUES);
  useEffect(() => {
    setData({
      users: [
        {
          value: "trex"
        },
        {
          value: "velociraptor"
        }
      ]
    });
  }, []);

  return (
    <div className="App">
      <Formik
        initialValues={data}
        enableReinitialize={true}
        validateOnChange={true}
        validateSchema={usersSchema}
        render={({ values, errors, touched, isValid, isValidating }) => {
          console.log("render - isValid", isValid);
          console.log("render - isValidating", isValidating);
          console.log("render - errors", errors);
          return (
            <Form>
              <Field name="users[0].value" />
              <div>{`isValid = ${isValid}`}</div>
              {Object.keys(errors) > 0 ? (
                <div>{`Error: ${JSON.stringify(errors)}`}</div>
              ) : null}
            </Form>
          );
        }}
      />
    </div>
  );
}

并且页面上没有错误。当我在输入中添加新的字符时,我希望看到字符串化的错误(s)和isValid = false。

reactjs formik yup
1个回答
0
投票

你的Yup架构是正确的,它只是道具名称不是。它应该是validationSchema而不是validateSchema

请注意,由于users[1]没有字段,因此表单永远不会有效(因为“velociraptor”超过三个字符)。但是您可能已经意识到这一点,并且只是以这种方式设置示例。

© www.soinside.com 2019 - 2024. All rights reserved.