Select2 jquery插件显示结果中所选项目的数量而不是标签

时间:2016-07-29 06:54:25

标签: javascript jquery select2

我正在使用 Select2 jQuery插件

https://select2.github.io/以供参考

当我使用多个下拉选项时。所选项目的结果在框中显示为标签,但我只想显示所选项目的数量。

是否可以使用 Select2 jQuery插件

HTML

<select multiple style="width:100%">
  <option value="1">Name1</option>
  <option value="2">Name2</option>
  <option value="3">Name3</option>
  <option value="4">Name4</option>
  <option value="5">Name5</option>
  <option value="6">Name6</option>
  <option value="7">Name7</option>
</select>

JS

$('select').select2();

我想要输出如下

enter image description here

而不是像输出一样的标签。

Example working Fiddle

2 个答案:

答案 0 :(得分:5)

您可以在初始化select2

后添加此代码
$('select').on('select2:close', function (evt) {
        var uldiv = $(this).siblings('span.select2').find('ul')
        var count = $(this).select2('data').length
        if(count==0){
          uldiv.html("")
        }
        else{
          uldiv.html("<li>"+count+" items selected</li>")
        }

参考:jsfiddle
参考select2事件:Here

编辑:
如果要在用户取消选择所有内容时显示空白, 使用这个小提琴:here

编辑:
更新以删除取消选择数据的缺陷并将其更改为主答案。 小提琴:here

答案 1 :(得分:2)

选择器肯定可以改进,但作为蓝图,在更改时添加计数器元素并隐藏这样的标签似乎按照要求工作。

$('select').select2({closeOnSelect: false}).on("change", function(e) {
  $('.select2-selection__rendered li:not(.select2-search--inline)').hide();
  $('.counter').remove();
  var counter = $(".select2-selection__choice").length;
  $('.select2-selection__rendered').after('<div style="line-height: 28px; padding: 5px;" class="counter">'+counter+' selected</div>');
});
.counter{
  position:absolute;
  top:0px;
  right:5px;
 }
 .select2-search--inline{
   background-color:Gainsboro;
 }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/js/select2.full.min.js"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/css/select2.min.css" rel="stylesheet"/>
<select multiple style="width:100%" id="mySelect">
  <option value="1">Name1</option>
  <option value="2">Name2</option>
  <option value="3">Name3</option>
  <option value="4">Name4</option>
  <option value="5">Name5</option>
  <option value="6">Name6</option>
  <option value="7">Name7</option>
</select>