这个select2组件的功能确实很强大,可以将图片放入到select里面随着文字一起显示。
组件的下载地址以及API说明地址:
1、Select2使用示例地址:https://select2.github.io/examples.html 、http://select2.github.io/select2/
2、Select2参数文档说明:https://select2.github.io/options.html
3、Select2源码:https://github.com/select2/select2
效果图:
HTML代码:
@{ Layout = "~/Views/Shared/_Layout.cshtml"; } <script src="/Content/jquery-3.1.1/jquery-3.1.1.min.js" type="text/javascript">script> <script src="/Content/bootstrap-3.3.0/js/bootstrap.min.js" type="text/javascript">script> <link href="/Content/bootstrap-3.3.0/css/bootstrap.min.css" rel="stylesheet" type="text/css"/> <script src="/Content/Select2_4.0.3/dist/js/select2.full.min.js" type="text/javascript">script> <link href="/Content/Select2_4.0.3/dist/css/select2.min.css" rel="stylesheet" type="text/css" /> <script src="/Content/Select2_4.0.3/dist/js/i18n/zh-CN.js" type="text/javascript">script> <script src="/Content/jquery-placeholders-master/jquery.placeholders.min.js" type="text/javascript">script> @*<link href="http://select2.github.io/select2/bootstrap/css/bootstrap.css" rel="stylesheet"/> <link href="http://select2.github.io/font-awesome/css/font-awesome.min.css" rel="stylesheet"/> <link rel="stylesheet" href="http://fanyi.youdao.com/web2/styles/all-packed.css?572877" type="text/css"/> <script src="http://select2.github.io/js/jquery-1.7.1.min.js" type="text/javascript">script> <script src="http://select2.github.io/select2/bootstrap/js/bootstrap.min.js" type="text/javascript">script> <link href="http://select2.github.io/select2-3.5.3/select2.css?ts=2015-08-29T20%3A09%3A48%2B00%3A00" rel="stylesheet"/> <script src="http://select2.github.io/select2-3.5.3/select2.js?ts=2015-08-29T20%3A09%3A48%2B00%3A00" type="text/javascript">script>*@ <script type="text/javascript"> $(document).ready(function () { $("#test").select2(); //-------------------------------------- $("#test_1").select2({ language: "zh-CN", //设置 提示语言 width: "100%", //设置下拉框的宽度 theme: "classic" }); //------------------------------------------------------ $("#test_2").select2({ language: "zh-CN", //设置 提示语言 width: "100%", //设置下拉框的宽度 placeholder: "请选择", minimumInputLength: 10 //最小需要输入多少个字符才进行查询 }); //------------------------------------------------------- $("#test_3").select2({ language: "zh-CN", //设置 提示语言 width: "100%", //设置下拉框的宽度 placeholder: "请选择", tags: true, maximumSelectionLength: 2 //设置最多可以选择多少项 }); //---------------------------------------------------- $("#test_4").select2({ language: "zh-CN", //设置 提示语言 width: "100%", //设置下拉框的宽度 placeholder: "请选择", allowClear: true, tags: true, maximumSelectionLength: 2, //设置最多可以选择多少项 templateResult: function (state) { if (!state.id) { return state.text; } console.log(state.element.getAttribute("imgPath")); var $state = $('' + state.element.getAttribute("imgPath") + '" class="img-flag" /> ' + state.text + ''); return $state; }, templateSelection: function (state) { if (!state.id) return state.text; // optgroup var $state = $('' + state.element.getAttribute("imgPath") + '" class="img-flag" /> ' + state.text + ''); return $state; } }); //---------------------------------------------------------- $("#test_5").select2({ language: "zh-CN", //设置 提示语言 width: "100%", //设置下拉框的宽度 placeholder: "请选择", tags: true, maximumSelectionLength: 3, //设置最多可以选择多少项 templateResult: function (state) { if (!state.id) { return state.text; } console.log(state.element.getAttribute("imgPath")); var $state = $('' + state.element.getAttribute("imgPath") + '" class="img-flag" /> ' + state.text + ''); return $state; }, templateSelection: function (state) { if (!state.id) return state.text; // optgroup var $state = $('' + state.element.getAttribute("imgPath") + '" class="img-flag" /> ' + state.text + ''); return $state; } }).select2('val', ['HI', 'OR', 'NV']); //------------------------------------------------------------------- $("#test_6").select2({ language: "zh-CN", //设置 提示语言 width: "100%", //设置下拉框的宽度 placeholder: "请选择", tags: true, maximumSelectionLength: 3, //设置最多可以选择多少项 templateResult: function (state) { if (!state.id) { return state.text; } console.log(state.element.getAttribute("imgPath")); var $state = $('' + state.element.getAttribute("imgPath") + '" class="img-flag" /> ' + state.text + ''); return $state; }, templateSelection: function (state) { if (!state.id) return state.text; // optgroup var $state = $('' + state.element.getAttribute("imgPath") + '" class="img-flag" /> ' + state.text + ''); return $state; } }); //------------------------------------------------------------------ $("#test_7").select2({ ajax: { url: "Home/GetArea", dataType: 'json', delay: 250, data: function (params) { return { q: params.term, // search term page: params.page }; }, processResults: function (data, params) { params.page = params.page || 1; return { results: data.items, pagination: { more: (params.page * 30) < data.total_count } }; }, cache: true }, escapeMarkup: function (markup) { return markup; }, // let our custom formatter work minimumInputLength: 1, language: "zh-CN", //设置 提示语言 maximumSelectionLength: 3, //设置最多可以选择多少项 placeholder: "请选择", tags: false, //设置必须存在的选项 才能选中 templateResult: function (repo) { //搜索到结果返回后执行,可以控制下拉选项的样式 console.log("====================templateResult开始=================="); console.log(repo); console.log("====================templateResult结束=================="); if (repo.loading) return repo.text; var markup = "" + repo.text + ""; return markup; }, templateSelection: function (repo) { //选中某一个选项是执行 console.log("------------------templateSelection开始-------------------------------------"); console.log( repo); console.log("------------------templateSelection结束-------------------------------------"); return repo.full_name || repo.text; } }); $("#btn").click(function() { alert($("#test_4").select2("val")); }); //$("#test_5").prop("disabled", true); //设置是否可用 }); script> <article > 默认 <br/> <select style="width: 300px" id="test" class="form-control"> <optgroup label="Alaskan/Hawaiian Time Zone"> <option value="AK" imgPath="https://select2.github.io/vendor/images/flags/ak.png">Alaskaoption> <option value="HI" imgPath="https://select2.github.io/vendor/images/flags/hi.png">Hawaiioption> optgroup> <optgroup label="Pacific Time Zone"> <option value="CA" imgPath="https://select2.github.io/vendor/images/flags/ca.png">Californiaoption> <option value="NV" imgPath="https://select2.github.io/vendor/images/flags/nv.png">Nevadaoption> <option value="OR" imgPath="https://select2.github.io/vendor/images/flags/or.png">Oregonoption> <option value="WA" imgPath="https://select2.github.io/vendor/images/flags/wa.png">Washingtonoption> optgroup> <optgroup label="Mountain Time Zone"> <option value="AZ" imgPath="https://select2.github.io/vendor/images/flags/az.png">Arizonaoption> <option value="CO" imgPath="https://select2.github.io/vendor/images/flags/co.png">Coloradooption> <option value="ID" imgPath="https://select2.github.io/vendor/images/flags/id.png">Idahooption> <option value="MT" imgPath="https://select2.github.io/vendor/images/flags/mt.png">Montanaoption> <option value="NE" imgPath="https://select2.github.io/vendor/images/flags/ne.png">Nebraskaoption> <option value="NM" imgPath="https://select2.github.io/vendor/images/flags/nm.png">New Mexicooption> <option value="ND" imgPath="https://select2.github.io/vendor/images/flags/nd.png">North Dakotaoption> <option value="UT" imgPath="https://select2.github.io/vendor/images/flags/ut.png">Utahoption> <option value="WY" imgPath="https://select2.github.io/vendor/images/flags/wy.png">Wyomingoption> optgroup> <optgroup label="Central Time Zone"> <option value="AL">Alabamaoption> <option value="AR">Arkansasoption> <option value="IL">Illinoisoption> <option value="IA">Iowaoption> <option value="KS">Kansasoption> <option value="KY">Kentuckyoption> <option value="LA">Louisianaoption> <option value="MN">Minnesotaoption> <option value="MS">Mississippioption> <option value="MO">Missourioption> <option value="OK">Oklahomaoption> <option value="SD">South Dakotaoption> <option value="TX">Texasoption> <option value="TN">Tennesseeoption> <option value="WI">Wisconsinoption> optgroup> <optgroup label="Eastern Time Zone"> <option value="CT">Connecticutoption> <option value="DE">Delawareoption> <option value="FL">Floridaoption> <option value="GA">Georgiaoption> <option value="IN">Indianaoption> <option value="ME">Maineoption> <option value="MD">Marylandoption> <option value="MA">Massachusettsoption> <option value="MI">Michiganoption> <option value="NH">New Hampshireoption> <option value="NJ">New Jerseyoption> <option value="NY">New Yorkoption> <option value="NC">North Carolinaoption> <option value="OH">Ohiooption> <option value="PA">Pennsylvaniaoption> <option value="RI">Rhode Islandoption> <option value="SC">South Carolinaoption> <option value="VT">Vermontoption> <option value="VA">Virginiaoption> <option value="WV">West Virginiaoption> optgroup> select> <br/> ---------------------------------------------------- <br/> 1、可搜索选项 <select id="test_1" class="form-control"> <optgroup label="Alaskan/Hawaiian Time Zone"> <option value="AK" imgPath="https://select2.github.io/vendor/images/flags/ak.png">Alaskaoption> <option value="HI" imgPath="https://select2.github.io/vendor/images/flags/hi.png">Hawaiioption> optgroup> <optgroup label="Pacific Time Zone"> <option value="CA" imgPath="https://select2.github.io/vendor/images/flags/ca.png">Californiaoption> <option value="NV" imgPath="https://select2.github.io/vendor/images/flags/nv.png">Nevadaoption> <option value="OR" imgPath="https://select2.github.io/vendor/images/flags/or.png">Oregonoption> <option value="WA" imgPath="https://select2.github.io/vendor/images/flags/wa.png">Washingtonoption> optgroup> <optgroup label="Mountain Time Zone"> <option value="AZ" imgPath="https://select2.github.io/vendor/images/flags/az.png">Arizonaoption> <option value="CO" imgPath="https://select2.github.io/vendor/images/flags/co.png">Coloradooption> <option value="ID" imgPath="https://select2.github.io/vendor/images/flags/id.png">Idahooption> <option value="MT" imgPath="https://select2.github.io/vendor/images/flags/mt.png">Montanaoption> <option value="NE" imgPath="https://select2.github.io/vendor/images/flags/ne.png">Nebraskaoption> <option value="NM" imgPath="https://select2.github.io/vendor/images/flags/nm.png">New Mexicooption> <option value="ND" imgPath="https://select2.github.io/vendor/images/flags/nd.png">North Dakotaoption> <option value="UT" imgPath="https://select2.github.io/vendor/images/flags/ut.png">Utahoption> <option value="WY" imgPath="https://select2.github.io/vendor/images/flags/wy.png">Wyomingoption> optgroup> <optgroup label="Central Time Zone"> <option value="AL">Alabamaoption> <option value="AR">Arkansasoption> <option value="IL">Illinoisoption> <option value="IA">Iowaoption> <option value="KS">Kansasoption> <option value="KY">Kentuckyoption> <option value="LA">Louisianaoption> <option value="MN">Minnesotaoption> <option value="MS">Mississippioption> <option value="MO">Missourioption> <option value="OK">Oklahomaoption> <option value="SD">South Dakotaoption> <option value="TX">Texasoption> <option value="TN">Tennesseeoption> <option value="WI">Wisconsinoption> optgroup> <optgroup label="Eastern Time Zone"> <option value="CT">Connecticutoption> <option value="DE">Delawareoption> <option value="FL">Floridaoption> <option value="GA">Georgiaoption> <option value="IN">Indianaoption> <option value="ME">Maineoption> <option value="MD">Marylandoption> <option value="MA">Massachusettsoption> <option value="MI">Michiganoption> <option value="NH">New Hampshireoption> <option value="NJ">New Jerseyoption> <option value="NY">New Yorkoption> <option value="NC">North Carolinaoption> <option value="OH">Ohiooption> <option value="PA">Pennsylvaniaoption> <option value="RI">Rhode Islandoption> <option value="SC">South Carolinaoption> <option value="VT">Vermontoption> <option value="VA">Virginiaoption> <option value="WV">West Virginiaoption> optgroup> select> article> ================================ <br/> 2、可搜索选项(有搜索关键字控制) <article> <select id="test_2" class="form-control"> <optgroup label="Alaskan/Hawaiian Time Zone"> <option value="AK" imgPath="https://select2.github.io/vendor/images/flags/ak.png">Alaskaoption> <option value="HI" imgPath="https://select2.github.io/vendor/images/flags/hi.png">Hawaiioption> optgroup> <optgroup label="Pacific Time Zone"> <option value="CA" imgPath="https://select2.github.io/vendor/images/flags/ca.png">Californiaoption> <option value="NV" imgPath="https://select2.github.io/vendor/images/flags/nv.png">Nevadaoption> <option value="OR" imgPath="https://select2.github.io/vendor/images/flags/or.png">Oregonoption> <option value="WA" imgPath="https://select2.github.io/vendor/images/flags/wa.png">Washingtonoption> optgroup> <optgroup label="Mountain Time Zone"> <option value="AZ" imgPath="https://select2.github.io/vendor/images/flags/az.png">Arizonaoption> <option value="CO" imgPath="https://select2.github.io/vendor/images/flags/co.png">Coloradooption> <option value="ID" imgPath="https://select2.github.io/vendor/images/flags/id.png">Idahooption> <option value="MT" imgPath="https://select2.github.io/vendor/images/flags/mt.png">Montanaoption> <option value="NE" imgPath="https://select2.github.io/vendor/images/flags/ne.png">Nebraskaoption> <option value="NM" imgPath="https://select2.github.io/vendor/images/flags/nm.png">New Mexicooption> <option value="ND" imgPath="https://select2.github.io/vendor/images/flags/nd.png">North Dakotaoption> <option value="UT" imgPath="https://select2.github.io/vendor/images/flags/ut.png">Utahoption> <option value="WY" imgPath="https://select2.github.io/vendor/images/flags/wy.png">Wyomingoption> optgroup> <optgroup label="Central Time Zone"> <option value="AL">Alabamaoption> <option value="AR">Arkansasoption> <option value="IL">Illinoisoption> <option value="IA">Iowaoption> <option value="KS">Kansasoption> <option value="KY">Kentuckyoption> <option value="LA">Louisianaoption> <option value="MN">Minnesotaoption> <option value="MS">Mississippioption> <option value="MO">Missourioption> <option value="OK">Oklahomaoption> <option value="SD">South Dakotaoption> <option value="TX">Texasoption> <option value="TN">Tennesseeoption> <option value="WI">Wisconsinoption> optgroup> <optgroup label="Eastern Time Zone"> <option value="CT">Connecticutoption> <option value="DE">Delawareoption> <option value="FL">Floridaoption> <option value="GA">Georgiaoption> <option value="IN">Indianaoption> <option value="ME">Maineoption> <option value="MD">Marylandoption> <option value="MA">Massachusettsoption> <option value="MI">Michiganoption> <option value="NH">New Hampshireoption> <option value="NJ">New Jerseyoption> <option value="NY">New Yorkoption> <option value="NC">North Carolinaoption> <option value="OH">Ohiooption> <option value="PA">Pennsylvaniaoption> <option value="RI">Rhode Islandoption> <option value="SC">South Carolinaoption> <option value="VT">Vermontoption> <option value="VA">Virginiaoption> <option value="WV">West Virginiaoption> optgroup> select> article> =============================== <br/> 3、多选 <article> <select id="test_3" class="form-control js-example-placeholder-multiple js-states select2-hidden-accessible" multiple="multiple"> <optgroup label="Alaskan/Hawaiian Time Zone"> <option value="AK" imgPath="https://select2.github.io/vendor/images/flags/ak.png">Alaskaoption> <option value="HI" imgPath="https://select2.github.io/vendor/images/flags/hi.png">Hawaiioption> optgroup> <optgroup label="Pacific Time Zone"> <option value="CA" imgPath="https://select2.github.io/vendor/images/flags/ca.png">Californiaoption> <option value="NV" imgPath="https://select2.github.io/vendor/images/flags/nv.png">Nevadaoption> <option value="OR" imgPath="https://select2.github.io/vendor/images/flags/or.png">Oregonoption> <option value="WA" imgPath="https://select2.github.io/vendor/images/flags/wa.png">Washingtonoption> optgroup> <optgroup label="Mountain Time Zone"> <option value="AZ" imgPath="https://select2.github.io/vendor/images/flags/az.png">Arizonaoption> <option value="CO" imgPath="https://select2.github.io/vendor/images/flags/co.png">Coloradooption> <option value="ID" imgPath="https://select2.github.io/vendor/images/flags/id.png">Idahooption> <option value="MT" imgPath="https://select2.github.io/vendor/images/flags/mt.png">Montanaoption> <option value="NE" imgPath="https://select2.github.io/vendor/images/flags/ne.png">Nebraskaoption> <option value="NM" imgPath="https://select2.github.io/vendor/images/flags/nm.png">New Mexicooption> <option value="ND" imgPath="https://select2.github.io/vendor/images/flags/nd.png">North Dakotaoption> <option value="UT" imgPath="https://select2.github.io/vendor/images/flags/ut.png">Utahoption> <option value="WY" imgPath="https://select2.github.io/vendor/images/flags/wy.png">Wyomingoption> optgroup> <optgroup label="Central Time Zone"> <option value="AL">Alabamaoption> <option value="AR">Arkansasoption> <option value="IL">Illinoisoption> <option value="IA">Iowaoption> <option value="KS">Kansasoption> <option value="KY">Kentuckyoption> <option value="LA">Louisianaoption> <option value="MN">Minnesotaoption> <option value="MS">Mississippioption> <option value="MO">Missourioption> <option value="OK">Oklahomaoption> <option value="SD">South Dakotaoption> <option value="TX">Texasoption> <option value="TN">Tennesseeoption> <option value="WI">Wisconsinoption> optgroup> <optgroup label="Eastern Time Zone"> <option value="CT">Connecticutoption> <option value="DE">Delawareoption> <option value="FL">Floridaoption> <option value="GA">Georgiaoption> <option value="IN">Indianaoption> <option value="ME">Maineoption> <option value="MD">Marylandoption> <option value="MA">Massachusettsoption> <option value="MI">Michiganoption> <option value="NH">New Hampshireoption> <option value="NJ">New Jerseyoption> <option value="NY">New Yorkoption> <option value="NC">North Carolinaoption> <option value="OH">Ohiooption> <option value="PA">Pennsylvaniaoption> <option value="RI">Rhode Islandoption> <option value="SC">South Carolinaoption> <option value="VT">Vermontoption> <option value="VA">Virginiaoption> <option value="WV">West Virginiaoption> optgroup> select> article> =============================== <br/> 4、图文选项 <article> <select id="test_4" class="js-example-templating js-states form-control select2-hidden-accessible" multiple="multiple"> <optgroup label="Alaskan/Hawaiian Time Zone"> <option value="AK" imgPath="https://select2.github.io/vendor/images/flags/ak.png">Alaskaoption> <option value="HI" imgPath="https://select2.github.io/vendor/images/flags/hi.png">Hawaiioption> optgroup> <optgroup label="Pacific Time Zone"> <option value="CA" imgPath="https://select2.github.io/vendor/images/flags/ca.png">Californiaoption> <option value="NV" imgPath="https://select2.github.io/vendor/images/flags/nv.png">Nevadaoption> <option value="OR" imgPath="https://select2.github.io/vendor/images/flags/or.png">Oregonoption> <option value="WA" imgPath="https://select2.github.io/vendor/images/flags/wa.png">Washingtonoption> optgroup> <optgroup label="Mountain Time Zone"> <option value="AZ" imgPath="https://select2.github.io/vendor/images/flags/az.png">Arizonaoption> <option value="CO" imgPath="https://select2.github.io/vendor/images/flags/co.png">Coloradooption> <option value="ID" imgPath="https://select2.github.io/vendor/images/flags/id.png">Idahooption> <option value="MT" imgPath="https://select2.github.io/vendor/images/flags/mt.png">Montanaoption> <option value="NE" imgPath="https://select2.github.io/vendor/images/flags/ne.png">Nebraskaoption> <option value="NM" imgPath="https://select2.github.io/vendor/images/flags/nm.png">New Mexicooption> <option value="ND" imgPath="https://select2.github.io/vendor/images/flags/nd.png">North Dakotaoption> <option value="UT" imgPath="https://select2.github.io/vendor/images/flags/ut.png">Utahoption> <option value="WY" imgPath="https://select2.github.io/vendor/images/flags/wy.png">Wyomingoption> optgroup> <optgroup label="Central Time Zone"> <option value="AL">Alabamaoption> <option value="AR">Arkansasoption> <option value="IL">Illinoisoption> <option value="IA">Iowaoption> <option value="KS">Kansasoption> <option value="KY">Kentuckyoption> <option value="LA">Louisianaoption> <option value="MN">Minnesotaoption> <option value="MS">Mississippioption> <option value="MO">Missourioption> <option value="OK">Oklahomaoption> <option value="SD">South Dakotaoption> <option value="TX">Texasoption> <option value="TN">Tennesseeoption> <option value="WI">Wisconsinoption> optgroup> <optgroup label="Eastern Time Zone"> <option value="CT">Connecticutoption> <option value="DE">Delawareoption> <option value="FL">Floridaoption> <option value="GA">Georgiaoption> <option value="IN">Indianaoption> <option value="ME">Maineoption> <option value="MD">Marylandoption> <option value="MA">Massachusettsoption> <option value="MI">Michiganoption> <option value="NH">New Hampshireoption> <option value="NJ">New Jerseyoption> <option value="NY">New Yorkoption> <option value="NC">North Carolinaoption> <option value="OH">Ohiooption> <option value="PA">Pennsylvaniaoption> <option value="RI">Rhode Islandoption> <option value="SC">South Carolinaoption> <option value="VT">Vermontoption> <option value="VA">Virginiaoption> <option value="WV">West Virginiaoption> optgroup> select> article> <br/> ====================================== <br/> 5、默认选中某个选项 <article> <select id="test_5" class="form-control" multiple="multiple"> <optgroup label="Alaskan/Hawaiian Time Zone"> <option value="AK" imgPath="https://select2.github.io/vendor/images/flags/ak.png">Alaskaoption> <option value="HI" imgPath="https://select2.github.io/vendor/images/flags/hi.png">Hawaiioption> optgroup> <optgroup label="Pacific Time Zone"> <option value="CA" imgPath="https://select2.github.io/vendor/images/flags/ca.png">Californiaoption> <option value="NV" imgPath="https://select2.github.io/vendor/images/flags/nv.png">Nevadaoption> <option value="OR" imgPath="https://select2.github.io/vendor/images/flags/or.png">Oregonoption> <option value="WA" imgPath="https://select2.github.io/vendor/images/flags/wa.png">Washingtonoption> optgroup> <optgroup label="Mountain Time Zone"> <option value="AZ" imgPath="https://select2.github.io/vendor/images/flags/az.png">Arizonaoption> <option value="CO" imgPath="https://select2.github.io/vendor/images/flags/co.png">Coloradooption> <option value="ID" imgPath="https://select2.github.io/vendor/images/flags/id.png">Idahooption> <option value="MT" imgPath="https://select2.github.io/vendor/images/flags/mt.png">Montanaoption> <option value="NE" imgPath="https://select2.github.io/vendor/images/flags/ne.png">Nebraskaoption> <option value="NM" imgPath="https://select2.github.io/vendor/images/flags/nm.png">New Mexicooption> <option value="ND" imgPath="https://select2.github.io/vendor/images/flags/nd.png">North Dakotaoption> <option value="UT" imgPath="https://select2.github.io/vendor/images/flags/ut.png">Utahoption> <option value="WY" imgPath="https://select2.github.io/vendor/images/flags/wy.png">Wyomingoption> optgroup> <optgroup label="Central Time Zone"> <option value="AL">Alabamaoption> <option value="AR">Arkansasoption> <option value="IL">Illinoisoption> <option value="IA">Iowaoption> <option value="KS">Kansasoption> <option value="KY">Kentuckyoption> <option value="LA">Louisianaoption> <option value="MN">Minnesotaoption> <option value="MS">Mississippioption> <option value="MO">Missourioption> <option value="OK">Oklahomaoption> <option value="SD">South Dakotaoption> <option value="TX">Texasoption> <option value="TN">Tennesseeoption> <option value="WI">Wisconsinoption> optgroup> <optgroup label="Eastern Time Zone"> <option value="CT">Connecticutoption> <option value="DE">Delawareoption> <option value="FL">Floridaoption> <option value="GA">Georgiaoption> <option value="IN">Indianaoption> <option value="ME">Maineoption> <option value="MD">Marylandoption> <option value="MA">Massachusettsoption> <option value="MI">Michiganoption> <option value="NH">New Hampshireoption> <option value="NJ">New Jerseyoption> <option value="NY">New Yorkoption> <option value="NC">North Carolinaoption> <option value="OH">Ohiooption> <option value="PA">Pennsylvaniaoption> <option value="RI">Rhode Islandoption> <option value="SC">South Carolinaoption> <option value="VT">Vermontoption> <option value="VA">Virginiaoption> <option value="WV">West Virginiaoption> optgroup> select> article> <br/> ========================================= <br/> 6、某些选项不能选中 <select id="test_6" class="form-control"> <optgroup label="Alaskan/Hawaiian Time Zone"> <option value="AK" imgPath="https://select2.github.io/vendor/images/flags/ak.png">Alaskaoption> <option value="HI" imgPath="https://select2.github.io/vendor/images/flags/hi.png">Hawaiioption> optgroup> <optgroup label="Pacific Time Zone"> <option value="CA" disabled="disabled" imgPath="https://select2.github.io/vendor/images/flags/ca.png">Californiaoption> <option value="NV" imgPath="https://select2.github.io/vendor/images/flags/nv.png">Nevadaoption> <option value="OR" imgPath="https://select2.github.io/vendor/images/flags/or.png">Oregonoption> <option value="WA" disabled="disabled" imgPath="https://select2.github.io/vendor/images/flags/wa.png">Washingtonoption> optgroup> <optgroup label="Mountain Time Zone"> <option value="AZ" imgPath="https://select2.github.io/vendor/images/flags/az.png">Arizonaoption> <option value="CO" imgPath="https://select2.github.io/vendor/images/flags/co.png">Coloradooption> <option value="ID" imgPath="https://select2.github.io/vendor/images/flags/id.png">Idahooption> <option value="MT" imgPath="https://select2.github.io/vendor/images/flags/mt.png">Montanaoption> <option value="NE" imgPath="https://select2.github.io/vendor/images/flags/ne.png">Nebraskaoption> <option value="NM" imgPath="https://select2.github.io/vendor/images/flags/nm.png">New Mexicooption> <option value="ND" imgPath="https://select2.github.io/vendor/images/flags/nd.png">North Dakotaoption> <option value="UT" imgPath="https://select2.github.io/vendor/images/flags/ut.png">Utahoption> <option value="WY" imgPath="https://select2.github.io/vendor/images/flags/wy.png">Wyomingoption> optgroup> <optgroup label="Central Time Zone"> <option value="AL">Alabamaoption> <option value="AR">Arkansasoption> <option value="IL">Illinoisoption> <option value="IA">Iowaoption> <option value="KS">Kansasoption> <option value="KY">Kentuckyoption> <option value="LA">Louisianaoption> <option value="MN">Minnesotaoption> <option value="MS">Mississippioption> <option value="MO">Missourioption> <option value="OK">Oklahomaoption> <option value="SD">South Dakotaoption> <option value="TX">Texasoption> <option value="TN">Tennesseeoption> <option value="WI">Wisconsinoption> optgroup> <optgroup label="Eastern Time Zone"> <option value="CT">Connecticutoption> <option value="DE">Delawareoption> <option value="FL">Floridaoption> <option value="GA">Georgiaoption> <option value="IN">Indianaoption> <option value="ME">Maineoption> <option value="MD">Marylandoption> <option value="MA">Massachusettsoption> <option value="MI">Michiganoption> <option value="NH">New Hampshireoption> <option value="NJ">New Jerseyoption> <option value="NY">New Yorkoption> <option value="NC">North Carolinaoption> <option value="OH">Ohiooption> <option value="PA">Pennsylvaniaoption> <option value="RI">Rhode Islandoption> <option value="SC">South Carolinaoption> <option value="VT">Vermontoption> <option value="VA">Virginiaoption> <option value="WV">West Virginiaoption> optgroup> select> <br/> ====================================== <br/> 7、搜索动态加载下拉选项功能(即在用户输入搜索内容时动态去后台取数据) <article> <select id="test_7" class=" form-control " multiple="multiple"> select> article> <br/> ========================================= <button id="btn">获取选中的值button>
控制器action代码:
public class HomeController : Controller { public IEnumerable<string> areaList = new List<string>() { "北京市", "天津市", "重庆市", "上海市", "广州市", "长沙", "哈尔滨", "长春", "杭州市", "南京市", "福建市", "河北省", "山西省", "辽宁省", "吉林省", "黑龙江省", "江苏省", "浙江省", "安徽省", "福建省", "江西省", "山东省", "河南省", "湖北省", "湖南省", "广东省", "海南省", "四川省", "贵州省", "云南省", "陕西省", "甘肃省", "青海省", "台湾省", "内蒙古自治区", "广西壮族自治区", "西藏自治区", "宁夏回族自治区", "新疆维吾尔自治区", "香港特别行政区", "澳门特别行政区" }; public JsonResult GetArea(string q, string page) { var area = new { id = 1, name = "" }; var lstRes = areaList.Select((t, i) => new Area { id = i, text = t, element = "element" + i }); if (!string.IsNullOrEmpty(q.Trim())) { lstRes = lstRes.Where(x => x.text.Contains(q)); } var lstCurPageRes = string.IsNullOrEmpty(page) ? lstRes.Take(10) : lstRes.Skip(Convert.ToInt32(page) * 10 - 10).Take(10); return Json(new { items = lstCurPageRes, total_count = lstRes.Count() }, JsonRequestBehavior.AllowGet); } public ActionResult Index() { return View(); } }
namespace Select2Demo.Models { public class Area { public int id { get; set; } public string text { get; set; } public string element { get; set; } } }
详细demo下载地址: http://pan.baidu.com/s/1qYvpzo4 密码:yvag