首页 文章

jquery select2插件是否支持在下拉列表中使用替代行颜色?

提问于
浏览
2

我有一个下拉列表,我正在使用Select2 jquery plugon,效果很好 .

我遇到的一件事是一个用例,其中每个项目都很长,所以文本包装为3或4行 . 我想看看你是否可以设置下拉列表的样式以使其具有替代行颜色,以便更容易看到一个项目结束的位置,而另一个项目列表向下滚动时则开始 .

这可能吗?

2 回答

  • 3

    是的,它有可能,事实上它很容易,这就是你如何做到的:

    在css样式表中,为要以不同颜色显示的项创建一个类,例如:

    .oddRow {background-color:#CCC;}
    

    然后将该类添加到要在 select2 调用之前以不同颜色显示的 option 元素,如下所示:

    $(document).ready(function() { 
      $("#source optgroup option:odd").addClass('oddRow');
      $("#source").select2();
    });
    

    请参阅this Plunker中的工作示例或下面的嵌入代码段 .

    $(document).ready(function() { 
      $("#source optgroup option:odd").addClass('oddRow');
      $("#source").select2();
    });
    
    .oddRow {background-color:#CCC;}
    
    <script data-require="jquery@*" data-semver="2.1.1" src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
        <link data-require="select2@*" data-semver="3.5.0" rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/select2/3.5.0/select2.min.css" />
        <script data-require="select2@*" data-semver="3.5.0" src="//cdnjs.cloudflare.com/ajax/libs/select2/3.5.0/select2.min.js"></script>
    
    <select style="width:300px" id="source">
          <optgroup label="Alaskan/Hawaiian Time Zone">
            <option value="AK">Alaska</option>
            <option value="HI">Hawaii</option>
          </optgroup>
          <optgroup label="Pacific Time Zone">
            <option value="CA">California</option>
            <option value="NV">Nevada</option>
            <option value="OR">Oregon</option>
            <option value="WA">Washington</option>
          </optgroup>
          <optgroup label="Mountain Time Zone">
            <option value="AZ">Arizona</option>
            <option value="CO">Colorado</option>
            <option value="ID">Idaho</option>
            <option value="MT">Montana</option>
            <option value="NE">Nebraska</option>
            <option value="NM">New Mexico</option>
            <option value="ND">North Dakota</option>
            <option value="UT">Utah</option>
            <option value="WY">Wyoming</option>
          </optgroup>
          <optgroup label="Central Time Zone">
            <option value="AL">Alabama</option>
            <option value="AR">Arkansas</option>
            <option value="IL">Illinois</option>
            <option value="IA">Iowa</option>
            <option value="KS">Kansas</option>
            <option value="KY">Kentucky</option>
            <option value="LA">Louisiana</option>
            <option value="MN">Minnesota</option>
            <option value="MS">Mississippi</option>
            <option value="MO">Missouri</option>
            <option value="OK">Oklahoma</option>
            <option value="SD">South Dakota</option>
            <option value="TX">Texas</option>
            <option value="TN">Tennessee</option>
            <option value="WI">Wisconsin</option>
          </optgroup>
          <optgroup label="Eastern Time Zone">
            <option value="CT">Connecticut</option>
            <option value="DE">Delaware</option>
            <option value="FL">Florida</option>
            <option value="GA">Georgia</option>
            <option value="IN">Indiana</option>
            <option value="ME">Maine</option>
            <option value="MD">Maryland</option>
            <option value="MA">Massachusetts</option>
            <option value="MI">Michigan</option>
            <option value="NH">New Hampshire</option>
            <option value="NJ">New Jersey</option>
            <option value="NY">New York</option>
            <option value="NC">North Carolina</option>
            <option value="OH">Ohio</option>
            <option value="PA">Pennsylvania</option>
            <option value="RI">Rhode Island</option>
            <option value="SC">South Carolina</option>
            <option value="VT">Vermont</option>
            <option value="VA">Virginia</option>
            <option value="WV">West Virginia</option>
          </optgroup>
        </select>
    
  • 3

    您可以通过在css文件中添加两个css类,或者在包含select字段的文件顶部来执行此操作 .

    添加以下内容:

    .select2-results li:nth-child(2n+1){
        background-color:red;
    }
    

    其中 select2-resultsul 标签的外部类 . 所以如果你正在使用不同的课程,请更改它 .

相关问题