У меня есть скрытое поле в форме, созданной в Razor с помощью помощника @Html.HiddenFor
:
@Html.HiddenFor(model => model.BidID, new { id="bidItemID" })
Модель My View выглядит следующим образом:
public class BidEditVM
{
[Display(Name = "Bid ID")]
public int BidID { get; set; }
[StringLength(51)]
[Display(Name = "Customer Name")]
public string CustomerName { get; set; }
[StringLength(75)]
[Display(Name = "Bid Name")]
public string BidName { get; set; }
[Display(Name = "Amount")]
public decimal Amount { get; set; }
[Display(Name = "Time")]
public DateTime BidTime { get; set; }
}
HTML отображается, ненавязчивый javascript добавляет свои вещи в скрытое поле ввода, даже если он никогда не потребует проверки:
<input id="bidItemID" type="hidden" value="5198" name="BidID" data-val-required="The Bid ID field is required." data-val-number="The field Bid ID must be a number." data-val="true">
Самое странное, что добавляемое сообщение и проверка даже не являются частью модели представлениядля этого частичного представления.Вид выглядит следующим образом:
@model AuctionAdmin.Models.ViewModels.BidEditVM
@using (Ajax.BeginForm("UpdateBid", new AjaxOptions { HttpMethod = "Post", UpdateTargetId = "modalBidInfo" }))
{
@Html.ValidationSummary(true)
@Html.HiddenFor(model => model.BidID, new { id="bidItemID" })
<fieldset>
<legend>Edit Bid</legend>
<div class="display-label">@Html.LabelFor(model => model.CustomerName)</div>
<div class="display-field">
@Html.DisplayFor(model => model.CustomerName)
</div>
<div class="display-label">@Html.LabelFor(model => model.BidName)</div>
<div class="display-field">
@Html.DisplayFor(model => model.BidName)
</div>
<div class="editor-label">@Html.LabelFor(model => model.Amount)</div>
<div class="editor-field">
@Html.EditorFor(model => model.Amount)
</div>
<div class="editor-label">@Html.LabelFor(model => model.BidTime)</div>
<div class="editor-field">
@Html.EditorFor(model => model.BidTime)
</div>
</fieldset>
}
Откуда он получает эти метаданные и как его остановить?