如何使自定义DropDownList编辑器模板的Required属性在客户端运行?

时间:2013-01-15 14:05:14

标签: asp.net-mvc asp.net-mvc-4 data-annotations asp.net-mvc-viewmodel

我有DropDownLists的编辑器模板,标有以下属性:

[AttributeUsage(AttributeTargets.Property)]
public class DropDownListAttribute : UIHintAttribute
{
    public string SelectListName { get; set; }
    public DropDownListAttribute(string selectListName)
        : base("DropDownList", "MVC", selectListName)
    {
        SelectListName = selectListName;
    }
}

本身看起来像这样:

@using Comair.RI.UI.Core
@{
    var list = this.GetModelSelectList();
    var listWithSelected = new SelectList(list.Items, list.DataValueField, list.DataTextField, Model);
}
@Html.DropDownListFor(m => Model, listWithSelected, " - select - ")

我的问题是它只验证服务器端,这对于用户解决所有客户端验证非常烦人,只是提交并获得新的,意外的服务器端验证。

2 个答案:

答案 0 :(得分:1)

如果您的客户端验证不起作用,可能是由以下原因之一引起的:

  1. 您的web.config没有那个企业:

    <appSettings>
    <add key="ClientValidationEnabled" value="true" />
    <add key="UnobtrusiveJavaScriptEnabled" value="true" />
    </appSettings>
    
  2. 您忘记添加验证脚本:

    <script src="@Url.Content("~/Scripts/jquery.validate.min.js")"></script>
    <script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")"></script>
    
  3. 您的控件未被Html.BeginFormAjax.BeginForm

  4. 包围
  5. 如果使用以下内容,客户端验证可能会在更新到ASP.NET MVC 4后停止在EditorFor中工作:

    @Html.DropDownListFor(m => Model, listWithSelected, " - select - ")
    

    Model替换m可以解决问题:

    @Html.DropDownListFor(m => m, listWithSelected, " - select - ")
    

答案 1 :(得分:0)

设置所需的类

@Html.DropDownListFor(m => Model, listWithSelected, " - select - ", new { @class='required' })

请参阅ASP MVC 3: How can I do Client side Validation on a Select List?