gpt4 book ai didi

jquery - select2 - 制作所选选项文本的数组,其中键是选项值

转载 作者:行者123 更新时间:2023-12-01 07:06:14 25 4
gpt4 key购买 nike

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

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();

最佳答案

您可以在 select2 上执行 jQuery.each。

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

var option = $(this);

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

});

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

$('.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));

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

.output {
margin-top: 25px;
}
<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>

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

关于jquery - select2 - 制作所选选项文本的数组,其中键是选项值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44315115/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com