select2 - 生成所选选项的数组文本,其中键是选项值

时间:2017-06-01 18:58:04

标签: jquery jquery-select2 jquery-select2-4

使用带有多个选项的最新select2。当用户选择任何选项时,我需要创建所选选项值和文本的数组。为了获得价值,我使用:

var id=$('#select2_dropdown').val();

它使像id[]="value1", id[]="value2"等数组

现在我需要在<option>标记之间为文本创建相同的数组。在Get selected text from a drop-down list (select box) using jQuery找到了解决方案,因此添加了以下代码:

var name=$("#select2_dropdown option:selected").text();

虽然它适用于单一选择,但尝试将其与多个选择一起使用只会生成类似name=optiontext1optiontext2的字符串(所有选定选项的字符串合并为一个)

如何让它看起来像这样:name[value1]=optiontext1, name[value2]=optiontext2

没有运气就试过了:

var id=$("#select2_dropdown option:selected").text();
var name[id]=$("#select2_dropdown option:selected").text();

1 个答案:

答案 0 :(得分:4)

你可以在select2上做一个jQuery.each。

$("#select2_dropdown option:selected").each(function(){

  var option = $(this);

  var label = option.text();
  var value = option.value();

});

您可以将这些值推送到对象中,然后根据需要格式化数据。

&#13;
&#13;
$('.select2').select2({ placeholder: 'Please choose one.'});

$('#stringify').on('click',function(){
	
  var result = { };
	$('#feeling :selected').each(function() { var o = $(this); result[o.text()]=o.val() });
  
  $('#output').text(JSON.stringify(result));

});
&#13;
.select2 {
  min-width:200px;
}

.output {
  margin-top: 25px;
}
&#13;
<link href="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/css/select2.css" rel="stylesheet"/>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"/>
<script src="https://cdnjs.cloudflare.com/ajax/libs/select2/4.0.3/js/select2.js"></script>


<label for='feeling'>How are you feeling?</label>
<select multiple='multiple' id='feeling' class='select2'>
  <option value="1">Awake</option> 
  <option value="2">Tired</option> 
  <option value="3">Happy</option> 
  <option value="4">Sad</option> 
  <option value="5">Hungry</option> 
  <option value="6">Tearful</option> 
</select>

<button class='btn btn-primary' id="stringify">
  To JSON.
</button>

<div class='output well'>
  <span id='output'>
  </span>
</div>
&#13;
&#13;
&#13;

示例,演示如何对对象执行此操作,然后将其转换为JSON字符串。