首页 > 解决方案 > Bootstrap 多选下拉菜单

问题描述

我想使用@glyuck 在此示例中的多选下拉菜单

http://jsfiddle.net/surajkm33/tsomyckj/

<select id="divRatings" class="selectpicker" multiple data-size="5" data-selected-text-format="count>2">
    <option value="All" selected="selected">All Ratings</option>
    <option value="EC">EC (Early Childhood)</option>
    <option value="E">E (Everyone)</option>
    <option value="E10+">E10+ (Everyone 10+)</option>
    <option value="T">T (Teen)</option>
    <option value="M">M (Mature)</option>
    <option value="AO">AO (Adults Only)</option>
</select>

<script>
$('#divRatings').on('change', function(){
        var thisObj = $(this);
    var isAllSelected = thisObj.find('option[value="All"]').prop('selected');
    var lastAllSelected = $(this).data('all');
    var selectedOptions = (thisObj.val())?thisObj.val():[];
        var allOptionsLength = thisObj.find('option[value!="All"]').length;
     
     console.log(selectedOptions);
      var selectedOptionsLength = selectedOptions.length;
     
    if(isAllSelected == lastAllSelected){
    
    if($.inArray("All", selectedOptions) >= 0){
        selectedOptionsLength -= 1;      
    }
            
      if(allOptionsLength <= selectedOptionsLength){
      
      thisObj.find('option[value="All"]').prop('selected', true).parent().selectpicker('refresh');
      isAllSelected = true;
      }else{       
        thisObj.find('option[value="All"]').prop('selected', false).parent().selectpicker('refresh');
         isAllSelected = false;
      }
      
    }else{          
        thisObj.find('option').prop('selected', isAllSelected).parent().selectpicker('refresh');
    }
   
        $(this).data('all', isAllSelected);
}).trigger('change');
</script>

But I want the text to be "All ratings" when all options are selected, instead of "7 items selected".

关于如何实现这一目标的任何想法?我是JS新手,所以我不知道!

标签: javascripthtmlcssbootstrap-select

解决方案


您是否尝试过使用类似select2的东西


推荐阅读