Listbox options javascript select all,move left-right, move up-down

While working with Listboxes I had to write few small JavaScript snippets to perform certain tasks like selecting all options / seselecting all options or moving options up and down or swapping the options between two listboxes. I thought of sharing the JavaScript functions with you so that you can bookmark the article and use the code whenever you need them.

Listbox Select All / Deselect All JavaScript

Following is the JavaScript function for implementing select all, deselect all options in listbox.
function listbox_selectall(listID, isSelect) { var listbox = document.getElementById(listID); for(var count=0; count < listbox.options.length; count++) { listbox.options[count].selected = isSelect; } }
Code language: JavaScript (javascript)
The above javascript code is very straight forward. All you have to do it to pass the ID of listbox you need to perform select all/deselect all and a boolean value for select/deselect. For example if a listbox has an id “countryList” following can be the function call.
listbox_selectall('countryList', true); //select all the options listbox_selectall('countryList', false); //deselect all the options
Code language: JavaScript (javascript)

Listbox Move up/down options JavaScript

Following is the javascript function that you can use to add move up/down options functionality. User can select any option and move it up in the list or down.
function listbox_move(listID, direction) { var listbox = document.getElementById(listID); var selIndex = listbox.selectedIndex; if(-1 == selIndex) { alert("Please select an option to move."); return; } var increment = -1; if(direction == 'up') increment = -1; else increment = 1; if((selIndex + increment) < 0 || (selIndex + increment) > (listbox.options.length-1)) { return; } var selValue = listbox.options[selIndex].value; var selText = listbox.options[selIndex].text; listbox.options[selIndex].value = listbox.options[selIndex + increment].value listbox.options[selIndex].text = listbox.options[selIndex + increment].text listbox.options[selIndex + increment].value = selValue; listbox.options[selIndex + increment].text = selText; listbox.selectedIndex = selIndex + increment; }
Code language: JavaScript (javascript)
Thus, you can call this function with first argument as list id and second argument a string value ‘up’ or ‘down’ depending on where you want to move the selected option.
listbox_move('countryList', 'up'); //move up the selected option listbox_move('countryList', 'down'); //move down the selected option
Code language: JavaScript (javascript)

Listbox swap/move left-right options JavaScript

Following is the javascript code for moving selected options from one listbox to another.
function listbox_moveacross(sourceID, destID) { var src = document.getElementById(sourceID); var dest = document.getElementById(destID); for(var count=0; count < src.options.length; count++) { if(src.options[count].selected == true) { var option = src.options[count]; var newOption = document.createElement("option"); newOption.value = option.value; newOption.text = option.text; newOption.selected = true; try { dest.add(newOption, null); //Standard src.remove(count, null); }catch(error) { dest.add(newOption); // IE only src.remove(count); } count--; } } }
Code language: JavaScript (javascript)
Just call the function with two arguments, first is the source listbox id and second is the destination listbox id.
listbox_moveacross('countryList', 'selectedCountryList');
Code language: JavaScript (javascript)

Online Demo

Click here for the online demo.

Getting Values in Server side script

When you submit the form with Listbox, by default browser will submit only selected values from that selectbox. Thus if you want to submit values from right hand side select box, you first needs to select all those before form gets submitted. You can do this like below:
<script> function submit() { listbox_selectall('righthand_side_listbox_id', true); return true; } <form onsubmit="return submit()"> ... </form>
Code language: JavaScript (javascript)
This would select all the options before form gets submitted. Now you can retrieve options in your server side script from request as request parameter.

View Comments

  • Nice article, I am searching for the same using jQuery....

    And coming to the question which Agniraj has mentioned, Agniraj here is your answer, just check out the length of right list box and loop through the options, you will get all the options which are there in right list box.

    Hope this might :)

    Thanks,
    Vivek

    • when i am trying it is giving me error as The function add(___newOption0, null) is undefined for the type Element

  • Please email me on how could i select all the values on the listbox if my listbox name is like this

    [code] [/code]

    this is my javascript for selecting all the listbox items:
    [code]
    function selectall()
    {
    for(i=0;i<document.forms['frmcustom'].sections[].length;i++){
    document.forms['frmcustom'].sections[i].selected=true;
    }
    } [/code]

  • I noticed a few things while implementing this in PHP I'd like to share:

    1) If you provide a name property to the destination list box, the "name=" property has to be appended with '[]' at the end, to return an array of items, otherwise it only returns the first item in the destination list box. For example

    Use: ...
    Not: ...

    2) In the script function "listbox_moveacross(sourceID, destID)", the value of src.options.length needs to reflect the current sizeof src.options.length thru each iteration. In my implementation, I captured src.options.length into a local var ahead of the loop, in hopes of gaining some tick ecomony.

    So I did:
    var maxx = src.options.length;
    for(var count=0; count < maxx; count++)
    {
    ...
    }

    versus the example:
    for(var count=0; count < src.options.length; count++)
    {
    ...
    }

    I found out the hard way, I had to decrement var maxx along with the var count-- decrement. So the code line after count--; became maxx--;

    if(src.options[count].selected == true)
    {
    ...
    count--;
    maxx--;
    }

    Just a lesson learned.

    • Hi Darla,

      I have only just started programing and can not get the code you changed working for the select box more right. Can you post or e-mail me the javascript?
      How do I get the variables in PHP??
      $rightselect = mysql_real_escape_string($_POST['rightselect']);
      ? My seclect id and name are rightselect
      Many thanks for your help!

Share
Published by
Viral Patel
Tags: JavaScript listbox listbox moveup listbox selectall

Recent Posts

  • Java

Java URL Encoder/Decoder Example

Java URL Encoder/Decoder Example - In this tutorial we will see how to URL encode/decode…

5 years ago
  • General

How to Show Multiple Examples in OpenAPI Spec

Show Multiple Examples in OpenAPI - OpenAPI (aka Swagger) Specifications has become a defecto standard…

5 years ago
  • General

How to Run Local WordPress using Docker

Local WordPress using Docker - Running a local WordPress development environment is crucial for testing…

5 years ago
  • Java

Create and Validate JWT Token in Java using JJWT

1. JWT Token Overview JSON Web Token (JWT) is an open standard defines a compact…

5 years ago
  • Spring Boot

Spring Boot GraphQL Subscription Realtime API

GraphQL Subscription provides a great way of building real-time API. In this tutorial we will…

5 years ago
  • Spring Boot

Spring Boot DynamoDB Integration Test using Testcontainers

1. Overview Spring Boot Webflux DynamoDB Integration tests - In this tutorial we will see…

5 years ago