How do you remove all the options of a select box and then add one option and select it with jQuery?

JavascriptJqueryHtml SelectDynamic Html

Javascript Problem Overview


Using core jQuery, how do you remove all the options of a select box, then add one option and select it?

My select box is the following.

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

EDIT: The following code was helpful with chaining. However, (in Internet Explorer) .val('whatever') did not select the option that was added. (I did use the same 'value' in both .append and .val.)

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

EDIT: Trying to get it to mimic this code, I use the following code whenever the page/form is reset. This select box is populated by a set of radio buttons. .focus() was closer, but the option did not appear selected like it does with .selected= "true". Nothing is wrong with my existing code - I am just trying to learn jQuery.

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

EDIT: selected answer was close to what I needed. This worked for me:

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

But both answers led me to my final solution..

Javascript Solutions


Solution 1 - Javascript

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

Solution 2 - Javascript

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

Solution 3 - Javascript

why not just use plain javascript?

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

Solution 4 - Javascript

If your goal is to remove all the options from the select except the first one (typically the 'Please pick an item' option) you could use:

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

Solution 5 - Javascript

I had a bug in IE7 (works fine in IE6) where using the above jQuery methods would clear the select in the DOM but not on screen. Using the IE Developer Toolbar I could confirm that the select had been cleared and had the new items, but visually the select still showed the old items - even though you could not select them.

The fix was to use standard DOM methods/properites (as the poster original had) to clear rather than jQuery - still using jQuery to add options.

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

Solution 6 - Javascript

Not sure exactly what you mean by "add one and select it", since it will be selected by default anyway. But, if you were to add more than one, it would make more sense. How about something like:

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

Response to "EDIT": Can you clarify what you mean by "This select box is populated by a set of radio buttons"? A <select> element cannot (legally) contain <input type="radio"> elements.

Solution 7 - Javascript

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

Solution 8 - Javascript

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

Solution 9 - Javascript

> Just one line to remove all options from the select tag and after you can add any options then make second line to add options.

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

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

> One more short way but didn't tried

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

Solution 10 - Javascript

Thanks to the answers I received, I was able to create something like the following, which suits my needs. My question was somewhat ambiguous. Thanks for following up. My final problem was solved by including "selected" in the option that I wanted 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>

Solution 11 - Javascript

I've found on the net something like below. With a thousands of options like in my situation this is a lot faster than .empty() or .find().remove() from jQuery.

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;
}

More info here.

Solution 12 - Javascript

How about just changing the html to new data.

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

Another example:

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

Solution 13 - Javascript

  1. First clear all exisiting option execpt the first one(--Select--)

  2. Append new option values using loop one by one

    $('#ddlCustomer').find('option:not(:first)').remove();
    for (var i = 0; i < oResult.length; i++) {
       $("#ddlCustomer").append(new Option(oResult[i].CustomerName, oResult[i].CustomerID + '/' + oResult[i].ID));
    }
    

Solution 14 - Javascript

Another way:

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

Under this link, there are good practices https://api.jquery.com/select/

Solution 15 - Javascript

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

The first line of code will remove all the options of a select box as no option find criteria has been mentioned.

The second line of code will add the Option with the specified value("testValue") and Text("TestText").

Solution 16 - Javascript

Building on mauretto's answer, this is a little easier to read and understand:

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

To remove all the options except one with a specific value, you can use this:

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

This would be better if the option to be added was already there.

Solution 17 - Javascript

This will replace your existing mySelect with a new mySelect.

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

Solution 18 - Javascript

Uses the jquery prop() to clear the selected option

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

Solution 19 - Javascript

You can do simply by replacing html

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

Solution 20 - Javascript

  • save the option values to be appended in an object
  • clear existing options in the select tag
  • iterate the list object and append the contents to the intended select tag

var listToAppend = {'':'Select Vehicle','mc': 'Motor Cyle', 'tr': 'Tricycle'};

$('#selectID').empty();

$.each(listToAppend, function(val, text) {
    $('#selectID').append( new Option(text,val) );
  });

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

Solution 21 - Javascript

I saw this code in Select2 - Clearing Selections

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

This code works well with jQuery even without Select2

Solution 22 - Javascript

Cleaner give me Like it

   let data= []

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

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

Solution 23 - Javascript

I used vanilla javascript

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

Solution 24 - Javascript

Hope it will work

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

Solution 25 - Javascript

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

Solution 26 - Javascript

Try

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

function setOne() {
  console.log({mySelect});
  mySelect.innerHTML = `<option selected value="whatever">text</option>`;
}

<button onclick="setOne()" >set one</button>
<Select id="mySelect" size="9"> 
 <option value="1">old1</option>
 <option value="2">old2</option>
 <option value="3">old3</option>
</Select>

Solution 27 - Javascript

The shortest answer:

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

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionJay CorbettView Question on Stackoverflow
Solution 1 - JavascriptMattView Answer on Stackoverflow
Solution 2 - JavascriptMahzillaView Answer on Stackoverflow
Solution 3 - JavascriptShawnView Answer on Stackoverflow
Solution 4 - JavascriptmaurettoView Answer on Stackoverflow
Solution 5 - Javascriptrow1View Answer on Stackoverflow
Solution 6 - JavascriptBobby JackView Answer on Stackoverflow
Solution 7 - JavascriptHayden ChambersView Answer on Stackoverflow
Solution 8 - JavascriptjvarandasView Answer on Stackoverflow
Solution 9 - JavascriptKaushik shrimaliView Answer on Stackoverflow
Solution 10 - JavascriptJay CorbettView Answer on Stackoverflow
Solution 11 - JavascriptmariooshView Answer on Stackoverflow
Solution 12 - JavascriptShivView Answer on Stackoverflow
Solution 13 - JavascriptJaydeep ShilView Answer on Stackoverflow
Solution 14 - JavascriptJhon Intriago ThothView Answer on Stackoverflow
Solution 15 - JavascriptDev ChauhanView Answer on Stackoverflow
Solution 16 - JavascripthumbadsView Answer on Stackoverflow
Solution 17 - JavascriptBarunView Answer on Stackoverflow
Solution 18 - JavascriptmehrdadView Answer on Stackoverflow
Solution 19 - JavascriptNadeem ManzoorView Answer on Stackoverflow
Solution 20 - JavascriptNifemi Sola-OjoView Answer on Stackoverflow
Solution 21 - Javascriptmichael01angeloView Answer on Stackoverflow
Solution 22 - JavascriptCarlosView Answer on Stackoverflow
Solution 23 - JavascriptKazeem QuadriView Answer on Stackoverflow
Solution 24 - JavascriptMd. Russel HussainView Answer on Stackoverflow
Solution 25 - JavascriptLN NitharsanView Answer on Stackoverflow
Solution 26 - JavascriptKamil KiełczewskiView Answer on Stackoverflow
Solution 27 - Javascriptdouble_u1View Answer on Stackoverflow