给出下面的选择框。我希望能够动态添加新选项。
<select id="user_department_id" name="user[department_id]">
<option value=""> </option>
<option value="9">AAAAA</option>
<option value="11">BBBBB</option>
<option value="10">G</option>
<option value="12">Z</option>
<option value="">--</option>
<option value="add">Add a New</option>
</select>
我一直在使用以下内容添加新选项:
$('#user_department_id')
.prepend($("<option></option>")
.attr("value",data.id)
.text(data.title)
);
这里的问题是它位置不自然,它位于空占位符选项之上,而不是按字母顺序排序。有没有一种神奇的方法可以在正确的位置添加新的选择选项?
由于
答案 0 :(得分:2)
这将插入一个新的选项值(假设它已经排序)
$('#yourselectID option').each(function()
{
var option = $(this).text();
option = option.toLowerCase();
var test = option.toLowerCase();
if ( option > test)
{
$(this).before('<option value="'+test+'">' + test+ '</option>');
return false;
}
});
答案 1 :(得分:1)
我认为你可以使用.after('blah')和你描述的选择器。
例如:
$('#user_department_id option[value="12"]').after('<option value="13">Q</option>')
有用吗?
答案 2 :(得分:1)
正如我的评论所述,您可以删除不想排序的选项,然后将其添加回来。
注意:以下内容适用于您的情况,因为您最后需要--
和Add New
。
var selElem = document.getElementById('user_department_id')
var tmpAry = [];
var igOpt = [];
for (var i = 0; i < selElem.options.length; i++) {
if ($(selElem.options[i]).hasClass('ig')) {
igOpt.push([selElem.options[i].text,
selElem.options[i].value]);
continue;
}
tmpAry[i] = new Array();
tmpAry[i][0] = selElem.options[i].text;
tmpAry[i][1] = selElem.options[i].value;
}
tmpAry.sort();
//merge with ignored options
tmpAry = tmpAry.concat(igOpt);
//remove options
$(selElem).empty();
for (var i = 0; i < tmpAry.length; i++) {
var op = new Option(tmpAry[i][0], tmpAry[i][1]);
selElem.options[i] = op;
}
答案 3 :(得分:0)
不是很优雅,但应该这样做:
$('#user_department_id option').each(function() {
if(this.text > data.title) {
$(this).before('<option value="' + data.id + '">' + data.title + '</option>');
return false;
}
});
答案 4 :(得分:0)
将您的选项保存在一个对象数组中,并从该对象生成您的选择。然后将新项目添加到该阵列并重新生成您的选择。
$(function() {
// Any options always on the top
var topOptions = '<option value=""> </option>';
// Your middle, sorted options
var options = [{val: 9, text: "AAAAA"}, {val: 11, text: "BBBBB"},{val: 10, text: "G"},{val: 12, text: "Z"}];
// Any options always on the bottom
var bottomOptions = '<option value="">--</option><option value="add">Add a New</option>';
// Function to populate the select options from above data
function populateOptions(element, options) {
// Sort options
options = options.sort(function(a, b) {
return a.text.toLowerCase() > b.text.toLowerCase();
});
$(element).html('').append(topOptions);
for (var i = 0; i < options.length; i++) {
$('<option>').attr("value", options[i].val).text(options[i].text).appendTo($(element));
}
$(element).append(bottomOptions);
}
// Start by populating the select
populateOptions('#user_department_id', options);
// Add and repopulate when add requested
$('#user_department_id').on('change', function() {
if ($(this).val() == "add") {
// Add option to list
options.push({val: data.id, text: data.text});
// Repopulate select
populateOptions(this, options);
// Select the new item
$(this).val(data.id);
}
});
});
答案 5 :(得分:0)
您可以使用underscore's sortedIndex
找出插入项目的位置,然后使用jquery's after
函数将其插入该位置。这假设您希望按字母顺序按选项文本排序:
var option = '<option value="' + data.id + '">' + data.title + '</option>';
var index = _.sortedIndex($('#user_department_id option'), option, function(item) {
return $(item).text();
});
if(index === 0) {
$('#user_department_id').prepend(option);
} else {
$('#user_department_id option').eq(index - 1).after(option);
}