如何为select2 drop元素添加特定类?

时间:2015-11-13 12:13:12

标签: javascript jquery css jquery-select2

我有通过css定制的select2及其常规类和ID。

现在,我尝试自定义将提供给select2的特定类,然后在css中应用它。

我的问题:不是每个人说的选择,而是它的下降(与 select2-drop 类的div)附加到正文,怎么能我访问那个?

我已经尝试过了:

$(".element").select2(
                       {
                         minimumResultsForSearch: -1,
                         containerCssClass : "error"
                       }
                    );

但是类error不会继承到该div。

更新: 这是我正在讨论的图形元素(选项区域):

enter image description here

这是我想要添加特定类的被检查代码,所以我可以在CSS中使用它:

enter image description here

更新:jsfiddle

6 个答案:

答案 0 :(得分:29)

您可以使用dropdownCssClass将类添加到select2-drop。我读了整个插件来了解发生了什么。最后,我找到了这个选项。

 $(".jSelectbox").select2({
     containerCssClass: "error",
     dropdownCssClass: "test"
 });



$(".jSelectbox").select2({
  containerCssClass: "error",
  dropdownCssClass: "test"
});

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/select2/3.5.2/select2.css" rel="stylesheet" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/select2/3.5.2/select2.js"></script>
<select class="jSelectbox">
			<option value="AL">Alabama</option>
			<option value="AK">Alaska</option>
			<option value="AZ">Arizona</option>
			<option value="AR">Arkansas</option>
			<option value="CA">California</option>
			<option value="CO">Colorado</option>
			<option value="CT">Connecticut</option>
			<option value="DE">Delaware</option>
			<option value="FL">Florida</option>
			<option value="GA">Georgia</option>
			<option value="HI">Hawaii</option>                   
			<option value="ID">Idaho</option>
			<option value="IL">Illinois</option>
			<option value="IN">Indiana</option>
			<option value="IA">Iowa</option>
			<option value="KS">Kansas</option>
			<option value="KY">Kentucky</option>
			<option value="LA">Louisiana</option>
			<option value="ME">Maine</option>
			<option value="MD">Maryland</option>
			<option value="MA">Massachusetts</option>
			<option value="MI">Michigan</option>
			<option value="MN">Minnesota</option>
			<option value="MS">Mississippi</option>
			<option value="MO">Missouri</option>
			<option value="MT">Montana</option>
			<option value="NE">Nebraska</option>
			<option value="NV">Nevada</option>
			<option value="NH">New Hampshire</option>
			<option value="NJ">New Jersey</option>
			<option value="NM">New Mexico</option>
			<option value="NY">New York</option>
			<option value="NC" selected="">North Carolina</option>
			<option value="ND">North Dakota</option>
			<option value="OH">Ohio</option>
			<option value="OK">Oklahoma</option>
			<option value="OR">Oregon</option>
			<option value="PA">Pennsylvania</option>
			<option value="RI">Rhode Island</option>
			<option value="SC">South Carolina</option>
			<option value="SD">South Dakota</option>
			<option value="TX">Texas</option>
			<option value="TN">Tennessee</option>
			<option value="UT">Utah</option>
			<option value="VT">Vermont</option>
			<option value="VA">Virginia</option>
			<option value="WA">Washington</option>
			<option value="WV">West Virginia</option>
			<option value="WI">Wisconsin</option>
			<option value="WY">Wyoming</option>
			</select>
&#13;
&#13;
&#13;

Jsfiddle

答案 1 :(得分:3)

这取决于您使用的select2的版本。 html结构在其中一个版本中发生了变化。

这是小提琴的例子: https://jsfiddle.net/LpjcqbLu/

我只是将'错误'类放在选择框上。

.error + .select2-container, 
.error + .select2-container + .select2-container .select2-dropdown {
    border: 3px solid red !important;
}

在早期版本中,下拉列表并不接近选择框(在dom中),因此您必须使用javascript解决方案直接应用错误类。

答案 2 :(得分:3)

如果您添加containerCssClass,则

select2.full.js有效。完整版有此选项

答案 3 :(得分:3)

可以通过另一种方式实现 - 通过select2的数据* - (如果不想添加select2.full.js)。使用它:

 var select2 = $(".element").select2({/* Select2 Opts */});

确定。现在将var select2推送到控制台(用于理解),如:

 console.log($(select2).data('select2'));

你会看到这样的事情:

e {$element: init(1), id: "select2-....", options: e, listeners: Object, dataAdapter: d…}
 $container: init(1)
 $dropdown: init(1) <-- what you need!
 $element: init(1)
 $results: init(1)
 ....

好的,现在只需以相同的方式将指定的类(-es)添加到select2's dropdown

select2.data('select2').$dropdown.addClass("...");

此外,通过$(select2).data('select2')您可以访问其他select2元素(容器等)。

答案 4 :(得分:0)

$(".select").select2({
  selectionCssClass: "my-class-section",
  dropdownCssClass: "my-class-drop"
});

答案 5 :(得分:0)

这是添加类的最简单方法

$(".kt_select2").on('select2:open', function (e) {
    $('body').find('span.select2-dropdown--below').addClass('kt_select_pro');
    $('body').find('ul.select2-results__options').addClass('kt_select_pro');
});