我的模型上有这个
[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 类型。
我注意到的一件事是,当我直接添加带有 App 对象的视图时,根据需要检测到 AppName。但是当我使用具有 AppName 类型的 AppCONntent 执行此操作时,不会显示验证,但对于非字符串的其他隐藏字段,它可以工作。