基於bootstrap-multiselect.js的下拉框聯動

背景:當option特別多時,通常的下拉框選擇起來就有點力不從心了,因此使用multiselect是個很好的選擇,能夠經過輸入文字來選擇選項很方便,可是有一個須要下拉框聯動,網上找了半天才找到解決方法,在此分享一下css

一、先引入 <script src="~/Assets/js/bootstrap-multiselect.min.js"></script>bootstrap

    <link href="~/Assets/css/bootstrap-multiselect.css" rel="stylesheet" />ide

而後全局定義post

複製代碼
function RegSelect() {
            $('.multiselect').multiselect({
                buttonClass: 'btn btn-white ',
                enableFiltering: true,
                enableHTML: true,
                includeSelectAllOption: true,
                selectAllText: '全選',
                allSelectedText: '所有選中',
                nonSelectedText: '請選擇',
                nSelectedText: '個被選中',
                templates: {
                    button: '<button type="button" class="multiselect dropdown-toggle" data-toggle="dropdown"><span class="multiselect-selected-text"></span> &nbsp;<b class="fa fa-caret-down"></b></button>',
                    ul: '<ul class="multiselect-container dropdown-menu"></ul>',
                    filter: '<li class="multiselect-item filter"><div class="input-group"><span class="input-group-addon"><i class="fa fa-search"></i></span><input class="form-control multiselect-search" type="text"></div></li>',
                    filterClearBtn: '<span class="input-group-btn"><button class="btn btn-default btn-white btn-grey multiselect-clear-filter" type="button"><i class="fa fa-times-circle red2"></i></button></span>',
                    li: '<li><a tabindex="0"><label></label></a></li>',
                    divider: '<li class="multiselect-item divider"></li>',
                    liGroup: '<li class="multiselect-item multiselect-group"><label></label></li>'
                }


            });
        }
複製代碼

只須要在頁面加載時RegSelect();(只能調用一次,否則會出現問題)就能夠了this

二、兩個下拉框spa

複製代碼
<div class="form-group">
                    <label for="RepairOrg" class="col-sm-3 control-label">維修單位</label>
                    <div class="col-sm-9">
                        @Html.DropDownList("RepairOrgUID", ViewBag.OrgList as List<SelectListItem>, "請選擇", new { @class = "form-control multiselect", onchange = "OrgChange(this)", id = "RepairOrg" })
                    </div>

                </div>

                <div class="form-group">
                    <label for="RepairContact" class="col-sm-3 control-label">維修人</label>
                    <div class="col-sm-9">
                        @Html.DropDownList("RepairContactUID", ViewBag.ContactList as List<SelectListItem>, "請選擇", new { @class = "form-control multiselect", id = "RepairContact" })
                    </div>



                </div>
複製代碼

三、js代碼code

複製代碼
function OrgChange(obj, patientID) {
            var RepairOrg = $(obj).val();
            $.post("/TerminalManage/GetContactByOrg", { RepairOrg: RepairOrg }, function (data) {          
                var newCitys = new Array();
                var obj = new Object();
                obj = {
                    label: "請選擇",
                    value: ""
                };
                newCitys.push(obj);
                for (var i = 0; i < data.length; i++) {

                    obj = {
                        label: data[i].Text,
                        value: data[i].Value
                    };
                    newCitys.push(obj);
                    
                }

                $("#RepairContact").multiselect('dataprovider', newCitys);
                $('#RepairContact').multiselect('refresh');
            });
        }
複製代碼
相關文章
相關標籤/搜索