Select2 中的可选 optgroup

Posted

技术标签:

【中文标题】Select2 中的可选 optgroup【英文标题】:Selectable optgroups in Select2 【发布时间】:2015-08-29 11:25:04 【问题描述】:

我想创建带有缩进的多级 select2 选项,但我不想为此使用 optgroup 元素,因为我还想允许选择主要类别。如果选择2,有什么方法可以设置样式吗?

我的原始 html 选择如下所示:

<select class="js-select-multiple">
  <option class="l1">Option 1</option>
  <option class="l2">Suboption 1</option>
  <option class="l2">Suboption 2</option>
  <option class="l2">Suboption 3</option>
  <option class="l1">Option 2</option>
  ...
</select>
<script>$(".js-select-multiple").select2(maximumSelectionLength: 5);</script>

所以不使用 Select2 我可以将 text-indent 属性添加到 .l2 类。但是,Select2 似乎没有使用那些用于选项的类,因此对这些类进行样式设置将不起作用。

有什么解决方法吗?

【问题讨论】:

【参考方案1】:

您正确地认识到 Select2 不会将 &lt;option&gt; 标记中的 CSS 类带到结果列表中。这主要与没有明确地将结果列表绑定到现有的&lt;option&gt; 标记有关,并且还具有一组合理的默认值。之后添加迁移类的功能比移除它们更容易。

您可以通过覆盖templateResult 并从data.element 获取原始选项(其中data 是第一个参数)来做到这一点。

$('.select2').select2(
  templateResult: function (data)     
    // We only really care if there is an element to pull classes from
    if (!data.element) 
      return data.text;
    

    var $element = $(data.element);

    var $wrapper = $('<span></span>');
    $wrapper.addClass($element[0].className);

    $wrapper.text(data.text);

    return $wrapper;
  
);
.l2 
  padding-left: 1em;
<link href="//cdnjs.cloudflare.com/ajax/libs/select2/4.0.0/css/select2.css" rel="stylesheet"/>

<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/select2/4.0.0/js/select2.js"></script>

<select class="select2" style="width: 200px">
  <option class="l1">Option 1</option>
  <option class="l2">Suboption 1</option>
  <option class="l2">Suboption 2</option>
  <option class="l2">Suboption 3</option>
  <option class="l1">Option 2</option>
</select>

请注意,我也使用 padding-left 而不是 text-indent,这是 Select2 通常用于嵌套选项的。

【讨论】:

搜索框不能很好地使用这种方法。例如。如果您在选项 2 下添加子选项 4 并搜索 sub,您将不知道子选项属于哪个类别,因为 1 级类别将从结果中排除。

以上是关于Select2 中的可选 optgroup的主要内容,如果未能解决你的问题,请参考以下文章

Select2 v4.0 使 optgroups 可选

可选类中的可选属性 VS 可选字典中的可选值

Java 中的可选 orElse 可选

Swift 中的可选值是啥?

JavaScript中的可选参数[重复]

参数 SwiftUI 中的可选绑定