установите ширину ввода select2 (с помощью директивы Angular-ui)

StackOverflow https://stackoverflow.com//questions/12683907

Вопрос

У меня проблема с работой этого plunkr (select2 + angulat-ui).

http://plnkr.co/edit/NkdWUO?p=preview

При локальной настройке я получаю работу select2, но не могу установить ширину, как описано в документы.Он слишком узок для использования.

enter image description here

Спасибо.

РЕДАКТИРОВАТЬ:Неважно, что plnkr, я нашел здесь рабочую скрипкуhttp://jsfiddle.net/pEFy6/

Похоже, что select2 сворачивается до ширины первого элемента.Я мог бы установить ширину через бутстрап class="input-medium" .Все еще не уверен, почему angular-ui не принимает параметры конфигурации.

Это было полезно?

Решение

Вам необходимо указать ширину атрибута для разрешения, чтобы сохранить ширину элемента.

$(document).ready(function() { 
    $("#myselect").select2({ width: 'resolve' });           
});

Другие советы

В моем случае select2 откроется правильно, если таблеток будет ноль или более.

Но если бы была одна или несколько таблеток, и я удалил бы их все, она бы сжалась до наименьшей ширины.Мое решение было просто:

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

Это старый вопрос, но новую информацию все же стоит опубликовать...

Начиная с Select2 версии 3.4.0 есть атрибут dropdownAutoWidth который решает проблему и обрабатывает все нечетные случаи.Обратите внимание, что по умолчанию он не включен.Его размер динамически изменяется по мере того, как пользователь делает выбор, он добавляет ширину для allowClear если этот атрибут используется, и он также правильно обрабатывает текст-заполнитель.

$("#some_select_id").select2({
    dropdownAutoWidth : true
});

выберите2 V4.0.3

<select class="smartsearch" name="search" id="search" style="width:100%;"></select>

С> 4.0 из select2 я использую

$("select").select2({
  dropdownAutoWidth: true
});

Эти другие не сработали:

  • выпадающийCssClass:'большая капля'
  • ширина:'100%'
  • ширина:'решать'

добавьте CSS-контейнер метода в свой скрипт следующим образом:

$("#your_select_id").select2({
      containerCss : {"display":"block"}
});

он установит ширину вашего выбора так же, как ширина вашего div.

Установка ширины на «разрешение» мне не помогла.Вместо этого я добавил «ширину: 100%» к своему выбору и изменил CSS следующим образом:

.select2-offscreen {position: fixed !important;}

Это было единственное решение, которое сработало для меня (моя версия 2.2.1) ваш выбор займет все доступное место, это лучше, чем использование

class="input-medium"

из начальной загрузки, потому что выбор всегда остается в контейнере, даже после изменения размера окна (отзывчивый)

Вы можете попробовать вот так.Меня устраивает

$("#MISSION_ID").select2();

При запросе скрытия/показа или ajax нам необходимо повторно инициализировать плагин select2.

Например:

$("#offialNumberArea").show();
$("#eventNameArea").hide();

$('.selectCriteria').change(function(){
    var thisVal = $(this).val();
    if(thisVal == 'sailor'){
        $("#offialNumberArea").show();
        $("#eventNameArea").hide();
    }
    else
    {
        $("#offialNumberArea").hide();
        $("#eventNameArea").show();
        $("#MISSION_ID").select2();
    }
});

Более простое решение CSS, независимое от select2

//HTML
<select id="" class="input-xlg">
</select>
<input type="text" id="" name="" value="" class="input-lg" />

//CSS
.input-xxsm {
  width: 40px!important; //for 2 digits 
}

.input-xsm {
  width: 60px!important; //for 4 digits 
}

.input-sm {
  width: 100px!important; //for short options   
}

.input-md {
  width: 160px!important; //for medium long options 
}

.input-lg {
  width: 220px!important; //for long options    
}

.input-xlg {
  width: 300px!important; //for very long options   
}

.input-xxlg {
  width: 100%!important; //100% of parent   
}

Добавьте параметр разрешения ширины в функцию select2.

$(document).ready(function() { 
        $("#myselect").select2({ width: 'resolve' });           
});

После добавления приведенного ниже CSS в вашу таблицу стилей

.select2-container {
width: 100% !important;
}

Это решит проблему

В недавнем проекте, созданном с использованием Бутстрап 4, я попробовал все вышеперечисленные методы, но ничего не помогло.Мой подход заключался в редактировании библиотека CSS с использованием jQuery получить 100% на столе.

 // * Select2 4.0.7

$('.select2-multiple').select2({
    // theme: 'bootstrap4', //Doesn't work
    // width:'100%', //Doesn't work
    width: 'resolve'
});

//The Fix
$('.select2-w-100').parent().find('span')
    .removeClass('select2-container')
    .css("width", "100%")
    .css("flex-grow", "1")
    .css("box-sizing", "border-box")
    .css("display", "inline-block")
    .css("margin", "0")
    .css("position", "relative")
    .css("vertical-align", "middle")

Работающий Демо

$('.select2-multiple').select2({
        // theme: 'bootstrap4', //Doesn't work
        // width:'100%',//Doens't work
        width: 'resolve'
    });
    //Fix the above style width:100%
    $('.select2-w-100').parent().find('span')
        .removeClass('select2-container')
        .css("width", "100%")
        .css("flex-grow", "1")
        .css("box-sizing", "border-box")
        .css("display", "inline-block")
        .css("margin", "0")
        .css("position", "relative")
        .css("vertical-align", "middle")
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet"/>
<link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.7/css/select2.min.css" rel="stylesheet" />

<div class="table-responsive">
    <table class="table">
        <thead>
        <tr>
            <th scope="col" class="w-50">#</th>
            <th scope="col" class="w-50">Trade Zones</th>
        </tr>
        </thead>
        <tbody>
        <tr>
            <td>
                1
            </td>
            <td>
                <select class="form-control select2-multiple select2-w-100" name="sellingFees[]"
                        multiple="multiple">
                    <option value="1">One</option>
                    <option value="1">Two</option>
                    <option value="1">Three</option>
                    <option value="1">Okay</option>
                </select>
            </td>
        </tr>
        </tbody>
    </table>
</div>

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.7/js/select2.min.js"></script>

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top