私は私のモデルにこれを持っています
[Required]
public string AppName { get; set; }
私のレイアウトページに
<script src="@Url.Content("~/Scripts/jquery-ui-1.8.24.js")"></script>
<script src="@Url.Content("~/Scripts/jquery.unobtrusive-ajax.min.js")"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")"></script>
my view has this inside BeginForm
@Html.EditorFor(model => model.App.AppName, new { size = 35 })
@Html.ValidationMessageFor(model => model.App.AppName)
<input type="submit" value="Start Business" class="demo-button ui-state-default ui-corner-all" />
this is how its rendered
<input id="App_AppName" class="text-box single-line watermark" type="text" value="" name="App.AppName" data-val-required="The AppName field is required." data-val="true">
<span class="field-validation-valid" data-valmsg-replace="true" data-valmsg-for="App.AppName"></span>
送信を押すと、AppNameが必須であるという検証は行われませんが、空のフィールドでサーバーにポストバックするだけです。
私はvalidationMsgForで非表示としていくつかのフィールドを追加しましたが、それは機能しています。
だから私が持っているのは
public class AppContent
{
public App App { get; set; }
public bool CreateModal { get; set; }
public AppContent()
{
}
}
私の見解はAppContentタイプです。
私が気づいたことの1つは、Appオブジェクトを使用してビューを直接追加すると、必要に応じてAppNameが検出されることです。しかし、AppName型のAppCOntentを使用して実行すると、検証は表示されませんが、文字列以外の他の非表示フィールドでは機能します。