在导航上重置本机反应中的表单

时间:2021-07-04 07:58:52

标签: react-native expo formik react-navigation-v5

我正在尝试创建一个可以创建和编辑实体的 React Native 应用程序。

例如,用户。

我有一个包含名字和姓氏以及电子邮件地址的表单。 如果传递了用户参数,则表单应采用这些值。

然而,它只在第一次有效。之后,表单保留第一个值。

如何强制重新评估表单?

function FormScreen({ navigation, route }) {
  const formikRef = React.createRef();
  const initialValues = { firstName: "", lastName: "", email: "" };

  if (route.params && route.params.user) {
    if (route.params.user.firstName) {
      initialValues.firstName = route.params.user.firstName;
    }
    if (route.params.user.lastName) {
      initialValues.lastName = route.params.user.lastName;
    }
    if (route.params.user.email) {
      initialValues.email = route.params.user.email;
    }
  }

  const unsubscribeBlur = navigation.addListener("blur", (e) => {
    console.log("form blur");
    if (formikRef.current) {
      console.log("form reset");
      formikRef.current?.resetForm();
    }
  });

  return (
    <View style={{ flex: 1, alignItems: "center", justifyContent: "center" }}>
      <Formik
        innerRef={formikRef}
        initialValues={initialValues}
        validationSchema={Yup.object({
          firstName: Yup.string()
            .max(15, "Must be 15 characters or less")
            .required("Required"),
          lastName: Yup.string()
            .max(20, "Must be 20 characters or less")
            .required("Required"),
          email: Yup.string()
            .email("Invalid email address")
            .required("Required"),
        })}
        onSubmit={(values, { setSubmitting }) => {
          setTimeout(() => {
            alert(JSON.stringify(values, null, 2));
            setSubmitting(false);
          }, 400);
        }}
      >
        <Form>
          <label htmlFor="firstName">First Name</label>
          <Field name="firstName" type="text" />
          <ErrorMessage name="firstName" />

          <label htmlFor="lastName">Last Name</label>
          <Field name="lastName" type="text" />
          <ErrorMessage name="lastName" />

          <label htmlFor="email">Email Address</label>
          <Field name="email" type="email" />
          <ErrorMessage name="email" />

          <button type="submit">Submit</button>
        </Form>
      </Formik>
    </View>
  );
}

export default FormScreen;

我有代码可以在模糊状态下重置表单,但重置似乎没有任何作用。

您可以在小吃中找到完整的代码。 https://snack.expo.io/@hackzilla/create-and-edit-with-formik

2 个答案:

答案 0 :(得分:1)

因为您使用的是标签导航器。当您在它们之间切换时,主屏幕和表单屏幕不会重新安装。因此 formik 不会加载新的初始值。按照您的方式,您可以在每次表单屏幕聚焦时使用路由参数重置表单。但更好的方法是使用堆栈导航器,每次使用新实例创建一个表单。

   useFocusEffect(
    React.useCallback(() => {
      if (formikRef.current) {
        console.log("form reset");
        formikRef.current?.setValues(initialValues);
      }
    })
  );

答案 1 :(得分:0)

我们可以在提交后重置表单,以便清除所有字段。请尝试用下面提到的代码替换您的提交方法。

 onSubmit={(values, { setSubmitting, resetForm }) => {
          setTimeout(() => {
            alert(JSON.stringify(values, null, 2));
            setSubmitting(false);
            // reset the fields after submit
            resetForm();
          }, 400);
        }}