Код: Выделить всё
error: function(xhr) {
const errors = xhr.responseJSON?.ModelState;
if (errors) {
for (const [key, value] of Object.entries(errors)) {
$(`#${key}`).after(`${value}`);
}
}
}
Код: Выделить всё
return BadRequest(new {
Errors = ModelState.Values.SelectMany(v => v.Errors)
.Select(e => e.ErrorMessage)
});
< /code>
< /li>
[*] Плагин проверки jQuery: < /p>
$("#teacherForm").validate({
submitHandler: function(form) {
// AJAX submit
}
});
Что я ожидал
ModelState
[*] Динамически отображать их под соответствующими входами формы
[*] Поддерживать согласованность с стилями проверки начальной загрузки
Текущий код - контроллер API:
Код: Выделить всё
[HttpPut]
[Route("api/teachers/{id}")]
public IHttpActionResult UpdateTeacher(int id, [FromBody] Teacher teacher)
{
if (!ModelState.IsValid)
{
return BadRequest(ModelState); // Returns error object
}
// ... update logic
}
< /code>
ajax call: < /p>
$.ajax({
url: `/api/teachers/${teacherId}`,
type: 'PUT',
contentType: 'application/json',
data: JSON.stringify(teacherData),
success: function() { /* ... */ },
error: function(xhr) {
// NEED HELP: Cleanly display errors here
}
});
[*] Какой наиболее поддержанный способ отображать модель State ошибки для формирования полей? /> < /li>
Есть ли библиотеки /плагины, которые упрощают этот рабочий процесс? 4
Подробнее здесь: https://stackoverflow.com/questions/795 ... n-ajax-res