169 похожих чатов

Как можно обработать массив с ошибками и присобачить к конкретному

input ошибку? т.е. если есть ошибка в username из массива взять ошибку где есть поле username. Дом элемента для отображения ошибки нет, но это не суть.

19 ответов

3 просмотра

Бери либы для форм react-final-form/react-hook-form/куча других

Maxim-Ivanov Автор вопроса

клиентскую обработку валидации не делаю. Ошибка валидации прилетает мне с сервера

попроси бэкенд ошибки возвращать не массивом, а объектом, либо сам трансформируй в объект

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

const settersErr = { username: setUsernameErr, password: setPasswordErr, } Object.keys(registerValidateErr).forEach(key => settersErr[key](registerValidateErr[key]) )

Не важно

Но вообще лучше либа для форм

Я с телефона пишу, поэтому чуть сложнее помочь, увидел, что это массив объектов, поэтому немного перебор поменяется, но суть та же

Maxim-Ivanov Автор вопроса

понял. по ключам в массиве пробегусь. спасибо

Пожалуйста

Maxim-Ivanov Автор вопроса

я думаю это можно делать в useEffect в зависимость передать массив?

Да и при изменении данных, он обновит ошибки

Maxim-Ivanov Автор вопроса

а если в массиве при трансформации окажется два одинаковых поля, сообщения просто складывать ?

да, наверное да. тогда будет объект у которого ключ - название поля, а значение - массив ошибок

Maxim-Ivanov Автор вопроса

ну тогда думаю лучше на сервере переделать

да, в идеале сервер должен присылать нормально сразу

хуки

так у тебя просто же там. фильтруешь массив по строкам 'username', 'password' и т.д. Ну и собственно выводишь полученные значения.

И если несколько значений, то .join(', ')

Похожие вопросы

Обсуждают сегодня

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Где можно найти примеры эффективного "асинхронного" tcp сервера на C? Я видел select, kqueue, poll, epoll и т.д. Ввод-вывод неблокирующий, но обработка клиентов блокирующая
#
10
Всем доброго дня, ребят подскажите пожалуйста, если в курсе по ассемблеру используется MASM32, могу ли я использовать FASM? В чем явная разница и будет ли у меня все работать?
Botsman
17
Hi Everyone! To all Are you Looking for Interview Support at the Lowest Price? Look no further! Then contact us 👉We offer Interview Support :-for a low cost variety of tech...
Rambabu Nallamilli
3
Книга Юрова В.И пойдёт для обучения?
Botsman
24
Hello experts, Could someone kindly tell me how to run vacuum inside a plpgsql function? If you have any link please share. Thank you
Amol Palav
10
И ещё вопрос: можно ли типа как на дос как-то запариться и с помощью прерываний выводить текст, вместо функции printf ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
34
> Примечательно, что новый владелец удаляет из GitHub любые жалобы, указывающие на подозрительную активность или смену владельца, и, видимо, рассчитывает на то, что пользовате...
Alex Sherbakov
2
Карта сайта