使用核心jQuery,如何删除一个选择框的所有选项,然后添加一个选项并选择它?

我的选择框如下。

<Select id="mySelect" size="9"> </Select>

编辑:下面的代码有助于链接。但是,(在Internet Explorer中).val('whatever')没有选择添加的选项。(我确实在.append和.val中使用了相同的“value”。)

$('#mySelect').find('option').remove().end()
.append('<option value="whatever">text</option>').val('whatever');

编辑:试图让它模仿这段代码,每当页面/表单重置时,我使用以下代码。这个选择框由一组单选按钮填充。.focus()更接近,但该选项没有像.selected= "true"那样显示为已选中。我现有的代码没有问题-我只是想学习jQuery。

var mySelect = document.getElementById('mySelect');
mySelect.options.length = 0;
mySelect.options[0] = new Option ("Foo (only choice)", "Foo");
mySelect.options[0].selected="true";

编辑:所选的答案接近我所需要的。这招对我很管用:

$('#mySelect').children().remove().end()
.append('<option selected value="whatever">text</option>') ;

但这两个答案都让我找到了最终的解决方案。


$('#mySelect')
    .find('option')
    .remove()
    .end()
    .append('<option value="whatever">text</option>')
    .val('whatever')
;

不确定你所说的“添加一个并选择它”是什么意思,因为它无论如何都会被默认选中。但是,如果你要加一个以上的数,就更有意义了。比如:

$('select').children().remove();
$('select').append('<option id="foo">foo</option>');
$('#foo').focus();

回复“EDIT”:你能解释一下你所说的“此选择框由一组单选按钮填充”是什么意思吗?<select>元素不能(合法地)包含<input type="radio">元素。


感谢我收到的答案,我能够创建如下内容,这符合我的需求。我的问题有点模棱两可。谢谢你的跟进。我的最后一个问题通过在我想要选择的选项中加入“selected”来解决。

$(function() { $('#mySelect').children().remove().end().append('<option selected value="One">One option</option>') ; // clear the select box, then add one option which is selected $("input[name='myRadio']").filter( "[value='1']" ).attr( "checked", "checked" ); // select radio button with value 1 // Bind click event to each radio button. $("input[name='myRadio']").bind("click", function() { switch(this.value) { case "1": $('#mySelect').find('option').remove().end().append('<option selected value="One">One option</option>') ; break ; case "2": $('#mySelect').find('option').remove() ; var items = ["Item1", "Item2", "Item3"] ; // Set locally for demo var options = '' ; for (var i = 0; i < items.length; i++) { if (i==0) { options += '<option selected value="' + items[i] + '">' + items[i] + '</option>'; } else { options += '<option value="' + items[i] + '">' + items[i] + '</option>'; } } $('#mySelect').html(options); // Populate select box with array break ; } // Switch end } // Bind function end ); // bind end }); // Event listener end <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <label>One<input name="myRadio" type="radio" value="1" /></label> <label>Two<input name="myRadio" type="radio" value="2" /></label> <select id="mySelect" size="9"></select>


$('#mySelect')
    .empty()
    .append('<option value="whatever">text</option>')
    .find('option:first')
    .attr("selected","selected")
;

$('#mySelect')
    .empty()
    .append('<option selected="selected" value="whatever">text</option>')
;

我在IE7中有一个bug(在IE6中工作良好),其中使用上述jQuery方法将清除DOM中的选择,但不是在屏幕上。使用IE开发人员工具栏,我可以确认选择项已经被清除,并且有了新项,但从视觉上看,选择项仍然显示旧的项——即使你不能选择它们。

修复方法是使用标准的DOM方法/属性(如海报原始)来清除,而不是使用jQuery -仍然使用jQuery添加选项。

$('#mySelect')[0].options.length = 0;

$("#control").html("<option selected=\"selected\">The Option...</option>");

如果你的目标是从选择中删除除第一个选项(通常是“请选择一个项目”选项)之外的所有选项,你可以使用:

$('#mySelect').find('option:not(:first)').remove();

这将用一个新的mySelect替换现有的mySelect。

$('#mySelect').replaceWith('<Select id="mySelect" size="9">
   <option value="whatever" selected="selected" >text</option>
   </Select>');

为什么不直接使用javascript呢?

document.getElementById("selectID").options.length = 0;

使用jquery prop()清除所选选项

$('#mySelect option:selected').prop('selected', false);

把html改成新数据怎么样?

$('#mySelect').html('<option value="whatever">text</option>');

另一个例子:

$('#mySelect').html('
    <option value="1" selected>text1</option>
    <option value="2">text2</option>
    <option value="3" disabled>text3</option>
');

我在网上找到了如下的东西。在我的情况下,有成千上万的选项,这比jQuery中的.empty()或.find().remove()快得多。

var ClearOptionsFast = function(id) {
    var selectObj = document.getElementById(id);
    var selectParentNode = selectObj.parentNode;
    var newSelectObj = selectObj.cloneNode(false); // Make a shallow copy
    selectParentNode.replaceChild(newSelectObj, selectObj);
    return newSelectObj;
}

更多信息请点击这里。


基于mauretto的回答,下面的内容更容易阅读和理解:

$('#mySelect').find('option').not(':first').remove();

要删除所有选项,除了一个具有特定值的选项,您可以使用以下命令:

$('#mySelect').find('option').not('[value=123]').remove();

如果要添加的选项已经存在,那就更好了。


首先清除所有现有的选项,执行第一个选项(——Select——) 使用循环逐个添加新的选项值 $ (' # ddlCustomer ');(选项:不(:第一)).remove (); For (var I = 0;i < oResult.length;我+ +){ $ (" # ddlCustomer”)。添加新选项(oResult[我]。CustomerName, oResult[我]。CustomerID + '/' + oResult[i].ID)); }


只需替换html即可

$('#mySelect')
.html('<option value="whatever" selected>text</option>')
.trigger('change');

希望能奏效

$('#myselect').find('option').remove()
.append($('<option></option>').val('value1').html('option1'));

另一种方法:

$('#select').empty().append($('<option>').text('---------').attr('value',''));

在这个链接下,有一些好的实践https://api.jquery.com/select/


var select = $('#mySelect');
select.find('option').remove().end()
.append($('<option/>').val('').text('Select'));
var data = [{"id":1,"title":"Option one"}, {"id":2,"title":"Option two"}];
for(var i in data) {
    var d = data[i];
    var option = $('<option/>').val(d.id).text(d.title);
    select.append(option);
}
select.val('');

保存要追加到对象中的选项值 清除select标记中的现有选项 迭代列表对象并将内容附加到预期的选择标记

var listToAppend ={":'选择车辆','mc': '摩托车',' tr': '三轮车'}; $ (' # selectID ')空虚(); 美元。每个(listToAppend,函数(val,文本){ $ (" # selectID”)。追加(新选项(文本,val)); }); < script src = " https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js " > < /脚本>


$("#id option").remove();
$("#id").append('<option value="testValue" >TestText</option>');

第一行代码将删除选择框的所有选项,因为没有提到选项查找标准。

第二行代码将添加带有指定值("testValue")和文本("TestText")的选项。


我在Select2 -中看到这段代码 清除选择

$('#mySelect').val(null).trigger('change');

即使没有Select2,这段代码也可以很好地使用jQuery


只需一行从选择标签中删除所有选项,然后在您可以添加任何选项后,再做第二行添加选项。

$('.ddlsl').empty();

$('.ddlsl').append(new Option('Select all', 'all'));

还有一条很短的路,但我没有尝试

$('.ddlsl').empty().append(new Option('Select all', 'all'));

Try

mySelect.innerHTML = `<option selected value="whatever">text</option>`

函数setOne() { console.log ({mySelect}); mySelect。innerHTML = ' <option selected value="whatever">text</option> '; } <按钮onclick = " setOne ()> >设置一个< /按钮 <Select id="mySelect" size="9"> <选项值= " 1 " > old1 > < /选项 <选项值= " 2 " > old2 > < /选项 <选项值= 3 > old3 > < /选项 < /选择>


最简短的回答:

$('#mySelect option').remove().append('<option selected value="whatever">text</option>');

我使用了纯javascript

let select = document.getElementById("mySelect");
select.innerHTML = "";

清洁工给我喜欢

   let data= []

   let inp = $('#mySelect')
        inp.empty()

        data.forEach(el=> inp.append(  new Option(el.Nombre, el.Id) ))

Try

$('#mySelect')
.html('<option value="whatever">text</option>')
.find('option:first')
.attr("selected","selected");

OR

$('#mySelect').html('<option value="4">Value 4</option>
 <option value="5">Value 5</option>
<option value="6">Value 6</option>
<option value="7">Value 7</option>
<option value="8">Value 8</option>')
.find('option:first')
.prop("selected",true);