用jQuery实现可输入多选下拉组合框实例代码
【写在前面的话】网站上很多用各种插件,比如依赖bootstrap的bootstrap-select插件等。虽然这些框架可以实现很多功能,但因为在实际项目中,可能只会用到其中的某个功能,若是一概引入,会导致整个js加载过于笨重。比如前面提到的bootstrap-select插件,在不压缩的情况下,达到300多k。因此,为了实现一个可填写的下拉框有点得不偿失。
基于这种原因,于是私下用jquery写了一个比较简单的多选下拉可填写组合框。
container{ margin:20pxauto; padding:015px; 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:1pxsolidsilver; border-left:none; float:left; padding:0; margin:0; box-sizing:border-box; cursor:pointer; } .dropDown-menu{ margin:0; padding:015px10px; width:100%; border:1pxsolidsilver; 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; }
<divclass="container"> <spanclass="text-container">最爱的水果</span> <divclass="multipleSelectselectContainer"> <inputtype="text"class="selectedContent"> <divclass="dropDown-toggle">选择</div> <ulclass="dropDown-menudsn"> <liclass="items"> <spanclass="isSelectedText">苹果</span> <spanclass="isSelected"><inputtype="checkbox"></span> </li> <liclass="items"> <spanclass="isSelectedText">梨</span> <spanclass="isSelected"><inputtype="checkbox"></span> </li> <liclass="items"> <spanclass="isSelectedText">橘子</span> <spanclass="isSelected"><inputtype="checkbox"></span> </li> <listyle="text-align:right"> <buttontype="button"class="confirmSelect">确定</button> </li> </ul> </div> </div>
$('.isSelectedinput[type=checkbox]').on('click',function(){ varselectedItems=$(this).parents('.dropDown-menu').prevAll('.selectedContent').val().split(''); varthisItem=$(this).parent().prev().text(); varisExisted=0; varisChecked=$(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浏览器测试后同样可是正常使用。