reactjs 无法为DatePicker组件分配名称或ID以进行Yup验证

anauzrmj  于 2022-12-12  发布在  React
关注(0)|答案(1)|浏览(169)

我有一个使用Yup进行验证的Formik表单。我的一个字段是日期选择器,但我无法将其集成到Yup验证中。
下面的代码可以渲染组件,但是当我尝试将<DatePicker/> Package 在<Field name="date></Field>标记中时,什么也渲染不了。

const [fieldDate,setFieldDate] = useState ("");
const dateSchema = Yup.object().shape({
  date: Yup.date().required('Date is required'),
});
   const initialValues = {date:''};
    return (
     
      <div>

        <FormContainer>
             
              <Formik
                initialValues={initialValues}
                //validationSchema={loginValidationSchema}
                validationSchema={dateSchema}
                onSubmit={()=>{console.log ("ok")}}                
              >
                {({ isSubmitting, values, setFieldValue, handleChange, handleBlur, errors, touched }) => (
                <Form className="form">
                  <LocalizationProvider dateAdapter={DateFnsUtils}>
                    <DatePicker
                      label="Date"
                      value={fieldDate}
                      onChange={(newValue:any) => {
                       setFieldDate(newValue);
                      }}
                      renderInput={(params) => <TextField {...params} />}
                    />
                  </LocalizationProvider>
                    <div className="buttonWrapper">          
                          <SubmitButton  type="submit" className="SubmitButton">Submit</SubmitButton>           
                    </div>
                    
                </Form>
             )}
          </Formik>
         
        </FormContainer>
      </div>

这里是我的导入...我将它们包括在内是因为我发现MUI中有多个同名的库,它们具有不同的父目录和不同的要求,这在某种程度上增加了我通过在线解决方案解决此问题时的困惑:

import React, { useState} from "react";
import { Formik, Form, Field, ErrorMessage } from "formik";
import {FormContainer,FieldContainer, SubmitButton } from "../GlobalStyle";
import { TextField } from "@mui/material";
import * as Yup from "yup";
import "react-datepicker/dist/react-datepicker.css";

  import { LocalizationProvider } from '@mui/x-date-pickers/LocalizationProvider';
import DateFnsUtils from "@date-io/date-fns";
import { DatePicker } from '@mui/x-date-pickers/DatePicker';

谢谢你!

z9ju0rcb

z9ju0rcb1#

import React from "react";
import { Formik, Form, Field,  } from "formik";
import { TextField } from "@mui/material";
import * as Yup from "yup";

import { LocalizationProvider } from '@mui/x-date-pickers/LocalizationProvider';
import DateFnsUtils from "@date-io/date-fns";
import { DatePicker } from '@mui/x-date-pickers/DatePicker';

const dateSchema = Yup.object().shape({
  date: Yup.date().required('Date is required'),
});

const initialValues = { date: '' };

export const App = () => {

  return (
    <div>
      <Formik
        initialValues={initialValues}
        validateOnMount
        validationSchema={dateSchema}
        onSubmit={() => {
          console.log('ok');
        }}
      >
        <Form className="form">
          <Field name="date">
            {({ field, meta, form }) => (
              <LocalizationProvider dateAdapter={DateFnsUtils}>
                  <DatePicker
                    label="Date"
                    renderInput={(params) => <TextField {...params} />}
                    // Get your date value from your form
                    value={field.value}
                    // Set your date in the form
                    onChange={(date) => form.setFieldValue('date', date)}
                  />
                   {/* Error from yup */}
                  <div>{meta.error}</div>
              </LocalizationProvider>
            )}
          </Field>
          <div className="buttonWrapper">
            <button type="submit" className="SubmitButton">
              Submit
            </button>
          </div>
        </Form>
      </Formik>
    </div>
  );
};

export default App;

相关问题