select2 - Setting different width to input and dropdown

104,215

Solution 1

The property you used is not for controlling the dropdown width. You can use the dropdownCssClass property.

Here's a demo in jsFiddle.

JavaScript:

$(document).ready(function() { 
    $("#e1").select2({dropdownCssClass : 'bigdrop'}); 
});

CSS:

.bigdrop {
    width: 600px !important;
}

Please note that for more recent versions there is now a better solution! See Dave Amphlett's answer

Solution 2

Select2 includes 'dropdownAutoWidth' parameter which uses javascript to attempt to be wide enough for the dropdown contents.

$('#whatever').select2({dropdownAutoWidth : true});

This at least works with Select2 3.4.3 - I don't know how much earlier it was introduced.

Solution 3

$("#e1").select2({ width: '100%' });      

Try this. This will set the width of container to 100%

Solution 4

Even better solution. Use:

$('#e1').select2({width: 'resolve'});

Solution 5

Try this.

$(".js-example-basic-single").select2({dropdownAutoWidth : true});

Share:
104,215
naviram
Author by

naviram

Updated on July 08, 2022

Comments

  • naviram
    naviram almost 2 years

    I am using Select2 3.3.2

    I have very very long options in the select. Example:

    <select id="e1">
    <option value="AL">Alabama</option>
    <option value="WY">Wyoming</option>
    <option value="WY">very long long long text</option>
    <option value="WY">very long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long long text</option>
    </select>
    

    The purpose is to avoid wrapping of the options when the dropdown opens up.

    I would like to set long width for the dropdown when it opens up (for example - 800px, or even automatic evaluated width).

    But to keep the input with short width when the dropdown is closed (for example 300px).

    I followed this "Add option to set dropdown width" issue of select2.

    But I couldn't get it to work, the width of the options/dropdown is the same as the input's width and the options as wrapped to multiple lines.

    Here is the demo of my problem in jsfiddle - http://jsfiddle.net/ewwAX/

    Thank you all in advance for helping.