Это модель с ее проверкой:
[MetadataType(typeof(TagValidation))]
public partial class Tag
{
}
public class TagValidation
{
[Editable(false)]
[HiddenInput(DisplayValue = false)]
public int TagId { get; set; }
[Required]
[StringLength(20)]
[DataType(DataType.Text)]
public string Name { get; set; }
//...
}
Вот представление:
<h2>Create</h2>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
<legend>Tag</legend>
<div>@Html.EditorForModel()</div>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
И вот что получите renderd:
<form action="/Tag/Create" method="post">
<fieldset>
<legend>Tag</legend>
<div><input data-val="true" data-val-number="The field TagId must be a number." data-val-required="The TagId field is required." id="TagId" name="TagId" type="hidden" value="" />
<div class="editor-label"><label for="Name">Name</label></div>
<div class="editor-field"><input class="text-box single-line" data-val="true" data-val-length="The field Name must be a string with a maximum length of 20." data-val-length-max="20" data-val-required="The Name field is required." id="Name" name="Name" type="text" value="" /> <span class="field-validation-valid" data-valmsg-for="Name" data-valmsg-replace="true"></span></div>
...
</fieldset>
</form>
Проблема заключается в том, что валидация TagId генерируется. althoug thare не является обязательным атрибутом, установленным в свойстве TagId. Из-за этого я даже не могу пройти проверку на стороне клиента, чтобы создать новый тег в db.
Что мне не хватает?
Ответ 1
Я нашел ответ. Просто добавьте это в Application_Start
:
DataAnnotationsModelValidatorProvider.AddImplicitRequiredAttributeForValueTypes = false;
Ответ 2
Сделать типы значений модели представления нулевыми. По умолчанию они не обязательно будут.
Обратите внимание, что если вы поместите атрибут "required =" false "в html 5 (если вы установите html 5 в метаданных вашего doctype), он увидит" требуется "и сделает это необходимым. Вы можете использовать dojo -data-props =" required: false".
Ответ 3
Решение frennky удалено только data-val-required
, но в моем случае у меня все еще были data-val-number
и data-val
Мне пришлось добавить две строки ниже в Application_Start, чтобы избавиться от всего.
ModelValidatorProviders.Providers.Clear();
ModelValidatorProviders.Providers.Add(new DataAnnotationsModelValidatorProvider());
Ответ 4
Проблема заключается в том, что значение скрытого поля пусто. Это не должно происходить, если вы используете целочисленный тип. Я полагаю, что свойство TagId определено как тип NULL в классе Tag
. Поэтому либо присвойте ему значение перед визуализацией представления, либо используйте целочисленный тип:
[MetadataType(typeof(TagValidation))]
public partial class Tag
{
public int TagId { get; set; }
public string Name { get; set; }
}
чтобы сгенерированное скрытое поле выглядело следующим образом:
<input
data-val="true"
data-val-number="The field TagId must be a number."
data-val-required="The TagId field is required."
id="TagId"
name="TagId"
type="hidden"
value="0"
/>
Также обычно не следует запускать проверку на стороне клиента для этого скрытого поля.
Ответ 5
jquery проверить атрибут целевого cheking "disabled" html.
$(function () {
$("#TagId").attr("disabled", "disabled")
});
или используйте Nullable.
надеюсь, что этот код!
Ответ 6
С MVC4 вы также можете использовать это:
@{ Html.EnableClientValidation(false); }
@Html.EditorForModel()
@{ Html.EnableClientValidation(true); }
Ответ 7
Сопоставьте значения свойств модели или модели View-Model "nullabel". Это решит вашу проблему. Одна важная вещь, которая удаляет "требуемый" атрибут из вашего тега, иначе он будет принимать "требуемый"
Пример: -
public class ViewModle
{
public int? foo{get;set;}
}
Здесь в примере foo - целочисленный тип с нулевым значением, это больше не потребуется в mvc.
Надеюсь, это поможет вам.