如何更改select2标签颜色的css?

Posted

技术标签:

【中文标题】如何更改select2标签颜色的css?【英文标题】:How to change the css of color of select2 tags? 【发布时间】:2012-12-29 16:12:11 【问题描述】:

我刚开始使用项目从选择框中显示多个标签,效果很好,感谢库。

我只需要修改多值选择框中显示的标签的颜色或 css。现在标签的颜色显示为灰色,我想根据标签的类型将其更改为其他颜色。或者至少有办法改变默认颜色?

还可以更改标签的css类吗?有一个选项,例如formatResultCssClass,但是当我尝试通过该属性添加 css 类时,没有任何改变,如果有人能举例说明如何做到这一点,我将不胜感激?

编辑:解决问题的解决方法: 向 select2.defaults 添加一个新属性,用于表示所选对象的类。

$.fn.select2.defaults = 
...
    selectedTagClass: "",
...


addSelectedChoice: function (data) 
        var choice=$(
            "<li class='select2-search-choice " + this.opts.selectedTagClass + "'>" +
            "    <div><a href='#' onclick='return false;' class='select2-search-choice-close' tabindex='-1'><i class='icon-remove icon-white'/></a></div>" +
            "</li>"),
        id = this.id(data),
        val = this.getVal(),
        formatted;
...

并使用这个新属性初始化 select2:

$(".#select2Input").select2(placeholder: "Please Select Country", 
                    selectedTagClass: 'label label-info', // label label-info are css classes that will be used for selected elements
                    formatNoMatches: function ()  return "There isn't any country similar to entered query"; 
                );

【问题讨论】:

【参考方案1】:

要格式化标签,您可以使用函数 formatSelectionCssClass。

$("#mySelect").select2(
    formatSelectionCssClass: function (data, container)  return "myCssClass"; ,
);

或者您可以根据选项 id 添加一个 css 类:

$("#mySelect").select2(
    formatSelectionCssClass: function (data, container)  return data.id; ,
);

请记住,您需要在 css 类中同时覆盖 filter 和 background_color

【讨论】:

这是正确的答案,基于对文档的更新。谢谢。 @DuaneJ 有什么更新?我在官方文档中找不到对formatSelectionCssClass 的单一引用。 这行不通,这是一个小提琴:jsfiddle.net/sajjansarkar/o3eem7s0/1你能发一个例子吗?【参考方案2】:

首先 - 一个警告,这意味着您正在覆盖 select2 内部的 CSS,因此如果 select2 代码在以后发生更改,您还必须更改您的代码。目前没有formatChoiceCSS 方法(尽管它会很有用)。

要更改默认颜色,您必须覆盖具有此 CSS 类的标签的各种 CSS 属性:

.select2-search-choice 
    background-color: #56a600;
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f4f4f4', endColorstr='#eeeeee', GradientType=0 );
    background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, color-stop(20%, #f4f4f4), color-stop(50%, #f0f0f0), color-stop(52%, #e8e8e8), color-stop(100%, #eeeeee));
    background-image: -webkit-linear-gradient(top, #f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eeeeee 100%);
    background-image: -moz-linear-gradient(top, #f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eeeeee 100%);
    background-image: -o-linear-gradient(top, #f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eeeeee 100%);
    background-image: -ms-linear-gradient(top, #f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eeeeee 100%);
    background-image: linear-gradient(top, #f4f4f4 20%, #f0f0f0 50%, #e8e8e8 52%, #eeeeee 100%);
    -webkit-box-shadow: 0 0 2px #ffffff inset, 0 1px 0 rgba(0,0,0,0.05);
    -moz-box-shadow: 0 0 2px #ffffff inset, 0 1px 0 rgba(0,0,0,0.05);
    box-shadow: 0 0 2px #ffffff inset, 0 1px 0 rgba(0,0,0,0.05);
    color: #333;
    border: 1px solid #aaaaaa;

要根据标签的文本或选项 # 更改每个标签的类,您必须添加一个更改事件:

$("#select2_element").on("change", function(e)  
      if (e.added) 
          // You can add other filters here like
          // if e.val == option_x_of_interest or
          // if e.added.text == some_text_of_interest
          // Then add a custom CSS class my-custom-css to the <li> added
          $('.select2-search-choice:not(.my-custom-css)', this).addClass('my-custom-css');
      
);

您可以在此类中定义自定义背景颜色等:

li.my-custom-css 
       background-color: // etc etc

【讨论】:

我实际上做了类似的事情 =) 我在代码中添加了 formatChoiceCSS 的属性,并使用该属性添加新的 css 类并删除了 select2-search-choice 的属性。感谢您的回答 如果我们按照您的回答在条件基础上的特定标签上添加 css,那么如果我们删除任何标签,那么 css 也会从标签中删除。【参考方案3】:

在我的例子中,我需要显示“选择”的标签和正在添加的标签之间的区别。

这里的帮助是针对以前版本的 select2,用处不大。使用当前的 4.0 版本(其文档非常稀疏),我能够使用模板函数和一点点“聪明”来实现这一点。

第一步是对结果进行模板化(应该注意,在每次选择或删除操作时,都会为框中的每个选择触发)。这通常只返回将在生成的 LI 中出现的文本......但是我们希望将该文本包装在一个跨度中(并告诉 S2 不要通过返回一个对象来剥离 html),并为我们的类型使用自定义 CSS 类。在我的示例中,我使用 selected 属性来确定:

$('.select2_sortable').select2(
    tags: true,
    templateSelection: function(selection) 
        if(selection.selected) 
            return $.parseHTML('<span class="im_selected">' + selection.text + '</span>');
        
        else 
            return $.parseHTML('<span class="im_writein">' + selection.text + '</span>');
        
    
);

选择项目后生成的 HTML 应该是这样的:

<ul class="select2-selection__rendered ui-sortable" id="select2_rendered_smartselectbox_4">
    <li class="select2-selection__choice" title="John Doe">
        <span class="select2-selection__choice__remove" role="presentation">×</span>
        <span class="im_selected">John Doe</span>
    </li>
    <li class="select2-selection__choice" title="fdfsdfds">
        <span class="select2-selection__choice__remove" role="presentation">×</span>
    <span class="im_writein">fdfsdfds</span>
    </li>
    <li class="select2-search select2-search--inline ui-sortable-handle">
        <input class="select2-search__field" type="search" tabindex="-1" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false" role="textbox" placeholder="" style="width: 0.75em;">
    </li>
</ul>

但这还不够,因为我们需要访问父 LI,而不是 span 子。由于 CSS 不允许父选择器,我们必须运行一些 jQuery 来实现它。因为这些是重绘的,所以我们希望在 Select2 项的 selectremove 事件上运行此函数:

$('.select2_sortable').on("select2:select", function (ev) 
    updateSelectedParents();
);
$('.select2_sortable').on("select2:removed", function (ev) 
    updateSelectedParents();
);

function updateSelectedParents() 
    $('.im_selected').closest('li').addClass('im_connected_item');
    $('.im_writein').closest('li').addClass('im_writein_item');

最终导致:

<ul class="select2-selection__rendered ui-sortable" id="select2_rendered_smartselectbox_4">
    <li class="select2-selection__choice im_connected_item" title="John Doe">
        <span class="select2-selection__choice__remove" role="presentation">×</span>
        <span class="im_selected">John Doe</span>
    </li>
    <li class="select2-selection__choice im_writein_item" title="fdfsdfds">
        <span class="select2-selection__choice__remove" role="presentation">×</span>
    <span class="im_writein">fdfsdfds</span>
    </li>
    <li class="select2-search select2-search--inline ui-sortable-handle">
        <input class="select2-search__field" type="search" tabindex="-1" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false" role="textbox" placeholder="" style="width: 0.75em;">
    </li>
</ul>

并允许您根据 im_writein_itemim_connected_item CSS 类设置元素的样式。

【讨论】:

【参考方案4】:

你可以像这样访问标签容器:

formatSelectionCssClass = function(tag, container) 
    $(container).parent().addClass("my-css-class");
;

【讨论】:

parent() 是我所缺少的!【参考方案5】:

使用formatResultCssClasscontainerCssClassdropdownCssClass 选项在代码中指定类,使用adaptContainerCssClassadaptDropdownCssClass 选项在标记中指定类,甚至使用containerCssdropdownCss 选项来指定类在代码中指定内联样式。

如果你想知道为什么你从来没有使用过这些,他们weren't properly documented 不久前。

参考:http://ivaynberg.github.io/select2/>

【讨论】:

【参考方案6】:

对于那些只想更改某些 select2 框颜色的人:

不要直接修改select2-choice的Select2 CSS属性,而是使用select2为select2 div生成的ID(这将是#s2id_yourelementid)来选择它携带select2-choice类的子节点。

例如,如果我想修改应用 Select2 的元素#myelement,然后要更改颜色,我会在我的 css 中添加以下内容:

#s2id_myelement > .select2-choice
     background-color:blue;
 

【讨论】:

【参考方案7】:

添加这个 CSS 对我有用:

.select2-selection__choice 
  background-color: red !important;
  filter: progid: DXImageTransform.Microsoft.gradient( startColorstr='#f4f4f4', endColorstr='#eeeeee', GradientType=0);
  background-image: -webkit-linear-gradient(top, red 25%, yellow 52%, green 25%, purple 100%) !important;
  background-image: -moz-linear-gradient(top, red 25%, yellow 52%, green 25%, purple 100%) !important;
  background-image: -o-linear-gradient(top, red 25%, yellow 52%, green 25%, purple 100%) !important;
  background-image: -ms-linear-gradient(top, red 25%, yellow 52%, green 25%, purple 100%) !important;
  background-image: linear-gradient(top, red 25%, yellow 52%, green 25%, purple 100%) !important;
  -webkit-box-shadow: 0 0 2px #ffffff inset, 0 1px 0 rgba(0, 0, 0, 0.05) !important;
  -moz-box-shadow: 0 0 2px #ffffff inset, 0 1px 0 rgba(0, 0, 0, 0.05) !important;
  box-shadow: 0 0 2px #ffffff inset, 0 1px 0 rgba(0, 0, 0, 0.05) !important;
  color: white !important;
  border: 1px solid #aaaaaa !important;

小提琴示例:

http://jsfiddle.net/sajjansarkar/hvsvcc5r/

(是的,我疯狂地用颜色来证明我的观点 ;-))

【讨论】:

【参考方案8】:

我在下面使用

    .form-control
        border: 1px solid #cccccc!important;
    
    .select2-container .select2-selection--single 
        height: 48px !important;
        padding: 10px;
        border-radius: 0px;
        border: 1px solid #cccccc;
    
    .select2-container .select2-selection--multiple 
        height: 48px !important;
        padding: 5px;
        border-radius: 0px;
        border: 1px solid #cccccc;
    

【讨论】:

以上是关于如何更改select2标签颜色的css?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用css更改select2控件的字体颜色

Select2 悬停颜色与 CSS

如何使用 JavaScript 函数更改 CSS 值(颜色标签)? [复制]

CSS更改hr标签的颜色[重复]

如何更改表单标签内的 <hr> 标签颜色? [复制]

如何使用 css 更改一个选择框选项文本(select2)的字体大小?