Как создать схему Formik YUP с именами полей Dynami c? - PullRequest
0 голосов
/ 19 февраля 2020

Как создать схему YUP с динамическими c точечными именами полей? Приведенная ниже схема недопустима. Как бы я динамически проходил через Costs.0.item, Costs.1.item, Costs.2.item И Costs.0.amount, Costs.1.amount, Costs.2.amount? Любая помощь приветствуется!

const IpSchema = Yup.object().shape({

        Project_Title: Yup.string()
            .min(2, 'Too Short!')
            .max(255, 'Too Long!')
            .required('Required'),
        Costs.0.item: Yup.string()
            .min(2, 'Too Short!')
            .max(255, 'Too Long!')
            .required('Required'),
        Costs.1.item: Yup.string()
            .min(2, 'Too Short!')
            .max(255, 'Too Long!')
            .required('Required'),
        Costs.2.item: Yup.string()
            .min(2, 'Too Short!')
            .max(255, 'Too Long!')
            .required('Required'),
        Costs.0.amount: Yup.string()
            .min(2, 'Too Short!')
            .max(255, 'Too Long!')
            .required('Required'),
        Costs.1.amount: Yup.string()
            .min(2, 'Too Short!')
            .max(255, 'Too Long!')
            .required('Required'),
        Costs.2.amount: Yup.string()
            .min(2, 'Too Short!')
            .max(255, 'Too Long!')
            .required('Required'),

    });

Ответы [ 2 ]

1 голос
/ 01 марта 2020

Если вы используете YUP с formik, вы можете проверить это . На документации предоставлен пример. И в соответствии с документами вы можете сделать это следующим образом:

const IpSchema = Yup.object().shape({
  Project_Title: Yup.string()
                    .min(2, 'Too Short!')
                    .max(255, 'Too Long!')
                    .required('Required'),
  Costs: Yup.array().of(
              Yup.object()
                    .shape({
                      item: Yup.string()
                        .min(2, 'Too Short!')
                        .max(255, 'Too Long!')
                        .required('Required'),
                      amount: Yup.string()
                        .min(2, 'Too Short!')
                        .max(255, 'Too Long!')
                        .required('Required')
                    })
                ),
});
1 голос
/ 21 февраля 2020

Вы должны использовать yup.array в этом случае, то есть:

const IpSchema = Yup.object().shape({
  Project_Title: Yup.string()
                    .min(2, 'Too Short!')
                    .max(255, 'Too Long!')
                    .required('Required'),
  Costs: Yup.array().of(
    Yup.object({
      item: Yup.string()
               .min(2, 'Too Short!')
               .max(255, 'Too Long!')
               .required('Required')
      amount: Yup.string()
                 .min(2, 'Too Short!')
                 .max(255, 'Too Long!')
                 .required('Required')
    })
  ),
});
...