Проверка асинхронной формы с несколькими полями

Я пытаюсь проверить имя пользователя и адрес электронной почты с помощью своего экспресс-приложения, но в методе asyncValidate, когда я проверяю одно, другое состояние ошибки исчезает.

const asyncValidate = (values, dispatch, props, field) => {
    if (field === 'username') {
        const url = config.dev_api_url + `/validation/username/${values.username}`
        return axios.get(url).then(res => {
            if (res.data.username === true) {
                throw { username: 'Already exists' }
            }
        })
    } else if (field === 'email') {
        const url = config.dev_api_url + `/validation/email/${values.email}`
        return axios.get(url).then(res => {
            if (res.data.email === true) {
                throw { email: 'Already exists' }
            }
        })
    }
}

Вот функция, в которой я отображаю ошибку ввода.

renderInput = form => {
    let fieldClasses = 'field fluid'
    let inputClasses = 'ui fluid input '
    let messageType = ''
    let messageContent = ''
    let iconType = ''
    if (form.meta.error && form.meta.touched) {
        messageType = 'error'
        messageContent = form.meta.error
        fieldClasses += ' error'
        inputClasses += ' icon'
        iconType = 'error'
        if (form.meta.error === 'password_error') {
            messageContent = (
                <em>
                    <b>1 Uppercase</b> letter <br />
                    <b>1 Lowercase</b> letter <br />
                    <b>1 Number</b> <br />
                    At least <b>8 characters</b> long <br />
                </em>
            )
        }
    } else if (form.meta.touched) {
        inputClasses += ' icon'
        iconType = 'success'
    }
    return (
        <div className={fieldClasses}>
            <label>{form.label}</label>
            <div className={inputClasses}>
                <input {...form.input} autoComplete="off" type={form.type} placeholder={form.placeholder} />
                {this.renderIcon(iconType)}
            </div>
            {this.renderMessage(messageType, messageContent)}
        </div>
    )
}

Когда я выбрасываю новую ошибку, другая исчезает. вот несколько изображений.

img1

img2

img3


person Alejov    schedule 14.02.2019    source источник
comment
Первая ссылка на ваше изображение дает мне отказ в доступе. Не могли бы вы прислать доступную ссылку, чтобы я мог снова отредактировать ваш пост?   -  person Ryuujo    schedule 14.02.2019
comment
drive.google.com/open?id=11K_QHG_c_YhweyrNiZ-cFdvyUP35Kefj   -  person Alejov    schedule 14.02.2019
comment
Это папка с тремя изображениями   -  person Alejov    schedule 14.02.2019
comment
Пожалуйста, покажите код компонента, где вы установили код скрытия/отображения ошибки.   -  person Kajol Chaudhary    schedule 14.02.2019
comment
Да, конечно, подожди минутку.   -  person Alejov    schedule 14.02.2019


Ответы (2)


Я нашел не слишком грязный способ сделать это - на случай, если кому-то понадобится использовать редукционную форму:

const asyncValidate = ( values, dispatch, props, field ) => {
    let validationPromises = [
        {
            field: "field1",
            request: axios.get(`validationUrl1/${values.field1}`),
            error: "Error message 1"
        },
        {
            field: "field2",
            request: axios.get(`validationUrl2${values.field2}`),
            error: "Error message 2"
        }
    ]

    let promisesResolved = validationPromises.map(promise => promise.request.catch(error => ({ error })));

    return axios.all(promisesResolved).then(
        (args) => {
            let errors = {};
            args.forEach( (r, idx ) => {
                if(!r.error){
                    errors[validationPromises[idx].field] = validationPromises[idx].error
                }
            })
            if(Object.keys(obj).length > 0){
               throw errors
            }
        }
    )
  }
  

person AugBar    schedule 22.11.2019

Это будет кратко.

Это беспорядок, чтобы сделать это с помощью Redux-Form, поэтому я лучше использую Formik, он легче и просто справляется с необходимыми вещами, если вам не нужны некоторые функции redux-form, это путь.

https://jaredpalmer.com/formik/docs/overview

person Alejov    schedule 14.02.2019
comment
Вы можете передать функцию в каждое поле, чтобы проверить ее (она принимает промисы). - person Alejov; 15.02.2019