0

我的模型上有这个

    [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 执行此操作时,不会显示验证,但对于非字符串的其他隐藏字段,它可以工作。

4

3 回答 3

0

这是因为我有水印,我不得不使用占位符。

于 2013-03-08T19:52:50.103 回答
0

您必须在 web.config 中启用客户端验证。

<appSettings>
  <add key="ClientValidationEnabled" value="true" />
  <add key="UnobtrusiveJavaScriptEnabled" value="true" />
</appSettings>
于 2013-02-11T01:30:01.363 回答
0

你必须把这个脚本

<script src="@Url.Content("~/Scripts/jquery-1.5.1.min.js")" type="text/javascript"></script>
于 2013-02-11T08:27:39.630 回答