различия в проверке на стороне сервера и клиента добавление дополнительного интервала
У меня есть валидация, которая находится как на стороне сервера, так и на стороне клиента Когда проверка добавляется на стороне сервера, я получаю другую структуру, чем когда я делаю это на стороне клиента
Клиент
<span data-valmsg-replace="true" data-valmsg-for="Location" class="text-danger field-validation-error"><span for="Location" class="">The Location field is required.</span></span>
Серверная сторона
<span data-valmsg-replace="true" data-valmsg-for="Location" class="field-validation-error text-danger">Broken</span>
Проблема в том, что
<span for="Location" class="">
Является ли их способ заставить проверку на стороне сервера добавить дополнительный интервал? Или это способ заставить проверку на стороне клиента удалить дополнительный интервал?
Любая помощь ценится :)
Модель
public class LocationModel
{
[Required]
public int Id { get; set; }
[Required]
public string Location { get; set; }
}
Контроллер
[HttpPost]
public ActionResult LocationView(LocationModel lm)
{
ModelState.AddModelError("Location", "Broken");
return View();
}
Вид
@model WebApplication1.Models.LocationModel
@{
ViewBag.Title = "View";
}
<h2>View</h2>
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
<h4>LocationModel</h4>
<hr />
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
<div class="form-group">
@Html.LabelFor(model => model.Location, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Location, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Location, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<input type="submit" value="Create" class="btn btn-default" />
</div>
</div>
</div>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
1 ответ:
Не уверен, почему это проблема.
Но вот код, генерирующий дополнительный интервал. Код в jQuery.утверждать.JS.
showLabel: function( element, message ) { ... } else { // create error element error = $( "<" + this.settings.errorElement + ">" ) .attr( "id", elementID + "-error" ) .addClass( this.settings.errorClass ) .html( message || "" ); ... },
Значением по умолчанию для errorElement являетсяlabel , но jquery.утверждать.ненавязчивый.js изменяет его на span . Есть несколько способов изменить это поведение.
Но вот один, change jquery.утверждение.ненавязчивый.js
Откуда:
function onError(error, inputElement) { // 'this' is the form element ... if (replace) { container.empty(); error.removeClass("input-validation-error").appendTo(container); } ... }
Кому:
function onError(error, inputElement) { // 'this' is the form element ... if (replace) { container.empty().html(error.html()); } ... }
Надеюсь, это поможет!