Подтвердить что ты не робот

JQuery - варианты множественного выбора

Я пытаюсь захватить все выбранные элементы в следующем select multiple и разделить их запятой. Код ниже:

<select id="ps-type" name="ps-type" multiple="multiple" size="5">
    <option>Residential - Wall Insulation</option>
    <option>Residential - Attic /Crawl Space Insulation</option>
    <option>Residential - Foundation Insulation</option>
    <option>Residential - Exterior Roof System</option>
    <option>Commercial - Wall Insulation</option>
    <option>Commercial - Air Barrier System (Walltite)</option>
    <option>Commercial - Roof System</option>
</select>

Результат, который я ищу, следующий:

Жилая - Настенная изоляция, Коммерческая - Настенная изоляция,...

Спасибо за помощь. -B

4b9b3361

Ответ 1

Вы можете использовать селектор :selected и встроенную функцию $.map() как часть вашей цепочки.

$("option:selected").map(function(){ return this.value }).get().join(", ");

Ответ 2

Добавьте значения в массив и используйте join для создания строки:

var items = [];
$('#ps-type option:selected').each(function(){ items.push($(this).val()); });
var result = items.join(', ');

Ответ 3

В нескольких элементах выбора команда val элемента select возвращает массив выбранных значений параметров. Если значений нет, используется текст элемента:

var output = $("#ps-type").val().join(', ');

update: Однако, когда нет выбранных опций, val() возвращает null не пустой массив. Один из способов обойти это:

var output = ($("#ps-type").val() || []).join(', '); 

Вы можете поиграть с ним в этой демонстрации, которую я собрал.

Из документов:

В случае элементов <select multiple="multiple"> метод .val() возвращает массив, содержащий каждую выбранную опцию.

Ответ 4

var list = "";
$('#ps-type option:selected').each(function(){
  list += this.value + ", ";
});
return list.substr(0, list.length - 2);

Ответ 5

Что-то вроде этого должно сделать трюк:

var result = "";
$('#ps-type option:selected').each(function(i, item){ 
   result += $(this).val() + ", ";
});

Ответ 6

Здесь вы идете:

var result = new Array();

$("#ps-type option:selected").each(function() {
    result.push($(this).val());
});

var output = result.join(", ");

Ответ 7

$(function() {
        $('#colorselector').change(function(){
            $('.colors').hide();
            $('#' + $(this).val()).show();
        });
    });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<Select id="colorselector" multiple="multiple" size="2">
   <option value="red">Red</option>
   <option value="yellow">Yellow</option>
   <option value="blue">Blue</option>
</Select>
<div id="red" class="colors" style="display:none"> red... </div>
<div id="yellow" class="colors" style="display:none"> yellow.. </div>
<div id="blue" class="colors" style="display:none"> blue.. </div>

Ответ 8

Попробуйте следующее:

    var List = new Array();
    $('#ps-type option:selected').each(function () {
       if ($(this).length) {
              var sel= {
                  name: $this.text()
              }
       }
       List.push(sel);
    });
    var result = List.join(', ');