我们如何获取jQuery Select2下拉插件中的所有元素。
我已将Select2应用于输入类型=隐藏,然后使用Ajax填充它。
现在在一个实例中,我需要获取下拉列表中显示的所有值。
这是一个输入字段。
<input type="hidden" id="individualsfront" name="individualsfront" style="width:240px" value="" data-spy="scroll" required />
并且我已应用此输入字段
$("#individualsfront").select2({
multiple: true,
query: function (query){
var data = {results: []};
$.each(yuyu, function(){
if(query.term.length == 0 || this.text.toUpperCase().indexOf(query.term.toUpperCase()) >= 0 ){
data.results.push({id: this.id, text: this.text });
}
});
query.callback(data);
}
});
yuyu是来自某些AJAX调用的json,并填充了Select2。
现在,我希望在其他代码中获取Select2中的所有值。
答案 0 :(得分:3)
选项1:您可以直接使用data
对象
var results = [];
$("#individualsfront").select2({
multiple: true,
query: function (query){
var data = {results: []};
$.each(yuyu, function(){
if(query.term.length == 0 || this.text.toUpperCase().indexOf(query.term.toUpperCase()) >= 0 ){
data.results.push({id: this.id, text: this.text });
}
});
results = data.results; //<=====
query.callback(data);
}
});
并像这样使用它:
$('#individualsfront').on('open',function(){
$.each(results, function(key,value){
console.log("text:"+value.text);
});
});
选项2:请求该功能并使用(临时)类似的内容:
$('#individualsfront').on('open',function(){
$(".select2-result-label").each(function()
{
console.log($(this).text());
})
});
});
http://jsfiddle.net/ouadie/qfchH/1/
选项3:您可以使用 .select2("data");
但只有在没有选定元素时才会返回所有元素。
var arrObj = $("#individualsfront").select2("data");
for each(yuyu in arrObj)
{
console.log("id: "+yuyu.id+ ", value: "+yuyu.text);
}
击> <击> 撞击>
答案 1 :(得分:1)
我试图自己解决这个问题,发现你至少可以在select2中获得选项。
var options = $("#dropdown").find("option")
var optionsText = $("#dropdown").find("option[value='1']").text()
答案 2 :(得分:0)
function select2Options($elementSelect2) {
var data = [],
adapter = $elementSelect2.data().select2.dataAdapter;
$elementSelect2.children().each(function () {
if (!$(this).is('option') && !$(this).is('optgroup')) {
return true;
}
data.push(adapter.item($(this)));
});
return data;
}