jquery - 如何使用 selected.js 在 MVC 中实现客户端验证

标签 jquery asp.net-mvc-3 jquery-chosen client-side-validation

我使用 chosen.js 进行多项选择,通过 asp.net mvc3 实现。客户端验证无法使用此多选控件。

我实现的方式是,使用 Html.Dropdownlist 帮助器,一旦从 JavaScript 加载 dom $("#dropdown1").chosen()

它正在用 div 替换 Select。

下面是代码

回调代码

function (data) {
            $("#divnewdata").html(data);

            $("#ddlcode1").chosen({
                disable_search_threshold: 10,
                no_results_text: "Oops, nothing found!",
                disable_search: false,
            });

            $("#ddlCode1_chosen").find('.chosen-choices').removeClass('form-control').addClass('form-control');

            $("#ddlcode2").chosen({
                disable_search_threshold: 10,
                no_results_text: "Oops, nothing found!",
                disable_search: false,
            });

            $("#ddlcode2_chosen").find('.chosen-choices').removeClass('form-control').addClass('form-control');

            $.validator.setDefaults({
                ignore: []
            });

        }

从布局页面加载java脚本

<head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>@ViewBag.Title - My ASP.NET Application</title>
    @Styles.Render("~/Content/css")
    @Scripts.Render("~/bundles/modernizr")
    @Scripts.Render("~/bundles/jquery")
    @Scripts.Render("~/bundles/bootstrap")
    <script src="~/Scripts/jquery.unobtrusive-ajax.js"></script>
    <script>

            $('form').validate({
                ignore: []
            });
    </script>
    <script src="~/Scripts/Common/Common.js"></script>
</head> 

正在尝试下载部分 View

<script>
    $(document).ready(function () {
        $.validator.unobtrusive.parse("#formAddcodes");

        $.validator.setDefaults({
            ignore: []
        });
    });
</script>

<link href="~/Content/chosen.css" rel="stylesheet" />
<script src="~/Scripts/chosen.jquery.min.js"></script>
<script src="~/Scripts/Codes/Codes.js"></script>


@using (Html.BeginForm("AddCodes", "Codes", FormMethod.Post, new { id = "formAddcodes" }))
{
    @Html.AntiForgeryToken()

    <div class="form-horizontal">
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
                <div class="form-group">
            @Html.LabelFor(model => model.code1, htmlAttributes: new { @class = "col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(model => model.code1, Model.Code1List as SelectList, new { @class = "form-control", id = "ddlcode1", multiple = "multiple" })
                @Html.ValidationMessageFor(model => model.code1, "", new { @class = "text-danger" })
            </div>
        </div>

        <div class="form-group">
            @Html.LabelFor(model => model.code2, htmlAttributes: new { @class = "col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(m => m.code2, Model.code2List as SelectList, new { @class = "form-control", id = "ddlcode2", multiple = "multiple" })
                @Html.ValidationMessageFor(model => model.code2, "", new { @class = "text-danger" })
            </div>
        </div>


        <div class="form-group">
            <div class="col-md-offset-2 col-md-10">
                <input type="submit" value="Add" class="btn btn-primary" />
            </div>
        </div>
    </div>
}

最佳答案

chosen通过制作原始 <select> 来更新 html默认情况下会忽略隐藏元素和隐藏元素。您可以使用以下脚本修改此行为

$.validator.setDefaults({ 
    ignore: []
});

$('form').validate({
    ignore: []
});

关于jquery - 如何使用 selected.js 在 MVC 中实现客户端验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30285222/

相关文章:

javascript - 页面加载时从下到上加载图像

asp.net-mvc-3 - 具有 MVC3、ASP.NET 成员资格的多用户应用程序 - 用户身份验证/数据分离

asp.net - 使用 Google 货币转换 API 时输入字符串格式不正确

jquery 在多选中选择了 Shift 选项?

PHP Multiselect with Chosen jQuery - 返回所有值而不仅仅是选择的值

jquery - 如何更改悬停时的图像源?

javascript - 使用 JQuery 打开关闭菜单

javascript - 这会在 IE 中泄漏吗?

asp.net-mvc-3 - 如何在 Asp.Net MVC3 中返回 Json 结果时填充 WebGrid

javascript - 选择下拉列表不显示(jquery-chosen)