用jQuery实现可输入多选下拉组合框实例代码
程序员文章站
2023-11-16 09:27:16
【写在前面的话】网站上很多用各种插件,比如依赖bootstrap的bootstrap-select插件等。虽然这些框架可以实现很多功能,但因为在实际项目中,可能只会用到...
【写在前面的话】网站上很多用各种插件,比如依赖bootstrap的bootstrap-select插件等。虽然这些框架可以实现很多功能,但因为在实际项目中,可能只会用到其中的某个功能,若是一概引入,会导致整个js加载过于笨重。比如前面提到的bootstrap-select插件,在不压缩的情况下,达到300多k。因此,为了实现一个可填写的下拉框有点得不偿失。
基于这种原因,于是私下用jquery写了一个比较简单的多选下拉可填写组合框。
container{ margin: 20px auto; padding:0 15px; width: 50%; height:300px; box-sizing: border-box; } .text-container{ display: inline-block; float:left; width: 15%; height: 32px; line-height: 32px; box-sizing: border-box; } .selectcontainer{ width: 70%; height:200px; float:left; position: relative; padding:0; margin:0; box-sizing: border-box; } .selectedcontent{ width:85%; height: 25px; float:left; } .dropdown-toggle{ width:14%; height:31px; line-height: 31px; text-align: center; border: 1px solid silver; border-left:none; float:left; padding:0; margin:0; box-sizing: border-box; cursor: pointer; } .dropdown-menu{ margin:0; padding:0 15px 10px; width:100%; border:1px solid silver; border-top: none; box-sizing: border-box; list-style: none; position: absolute; top:31px; right:0; } .items{ margin-top:8px; padding: 2px; cursor: pointer; } .items:hover{ background: #ddd; } .isselectedtext{ display: inline-block; width:90%; } .dsn{ display: none; }
<div class="container"> <span class="text-container">最爱的水果</span> <div class="multipleselect selectcontainer"> <input type="text" class="selectedcontent"> <div class="dropdown-toggle">选择</div> <ul class="dropdown-menu dsn"> <li class="items"> <span class="isselectedtext">苹果</span> <span class="isselected"><input type="checkbox"></span> </li> <li class="items"> <span class="isselectedtext">梨</span> <span class="isselected"><input type="checkbox"></span> </li> <li class="items"> <span class="isselectedtext">橘子</span> <span class="isselected"><input type="checkbox"></span> </li> <li style="text-align: right"> <button type="button" class="confirmselect">确定</button> </li> </ul> </div> </div>
$('.isselected input[type=checkbox]').on('click', function(){ var selecteditems = $(this).parents('.dropdown-menu').prevall('.selectedcontent').val().split(' '); var thisitem = $(this).parent().prev().text(); var isexisted = 0; var ischecked = $(this).is(':checked'); if(ischecked){ selecteditems.map(function(item, index){ if(item === thisitem){ isexisted++ } }); if(!isexisted){ selecteditems.push(thisitem) } } else{ selecteditems.map(function(item, index){ if(item === thisitem){ selecteditems.splice(index, 1); } }); } $(this).parents('.dropdown-menu').prevall('.selectedcontent').val(selecteditems.join(' ')); }) $('.confirmselect').on('click', function(){ $(this).parents('.dropdown-menu').addclass('dsn'); }) $('.dropdown-toggle').on('click', function(){ $(this).next().toggleclass('dsn') });
由于本组件中使用了数组的map方法,可能此方法在ie中不能兼容。由于鄙人电脑ie无法打开,用360浏览器测试后同样可是正常使用。
上一篇: JS中的phototype详解