如何获取Select2下拉列表中的所有值?

sus*_*ani 6 ajax jquery jquery-select2

我们如何获得jQuery Select2下拉插件中的所有元素.

我已将Select2应用于输入类型=隐藏,然后使用Ajax填充它.

现在在一个实例中,我需要获取下拉列表中出现的所有值.

这是一个输入字段.

<input type="hidden" id="individualsfront" name="individualsfront" style="width:240px" value="" data-spy="scroll" required />
Run Code Online (Sandbox Code Playgroud)

我已经应用了这个输入字段

$("#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);
    }
});
Run Code Online (Sandbox Code Playgroud)

yuyu是来自某些AJAX调用的json,并填充了Select2.

现在我想在其他一些代码中获取Select2中的所有值.

Ala*_*lao 6

我试图自己解决这个问题,发现您至少可以在 select2 中获得选项。

var options = $("#dropdown").find("option")
var optionsText = $("#dropdown").find("option[value='1']").text()
Run Code Online (Sandbox Code Playgroud)


Oua*_*die 5

选项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);
    }
});
Run Code Online (Sandbox Code Playgroud)

并像这样使用它:

$('#individualsfront').on('open',function(){
    $.each(results, function(key,value){
        console.log("text:"+value.text);
    });
});
Run Code Online (Sandbox Code Playgroud)

选项2:请求功能并使用(临时)类似:

$('#individualsfront').on('open',function(){
    $(".select2-result-label").each(function()
        {
            console.log($(this).text());
        })
    });
});
Run Code Online (Sandbox Code Playgroud)

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);
}
Run Code Online (Sandbox Code Playgroud)