js操作select大全

转载:http://deepfuture.iteye.com/blog/694085

1判断select选项中 是否存在Value="paraValue"的Item

2向select选项中 加入一个Item

3从select选项中 删除一个Item

4删除select中选中的项

5修改select选项中 value="paraValue"的text为"paraText"

6设置select中text="paraText"的第一个Item为选中

7设置select中value="paraValue"的Item为选中

8得到select的当前选中项的value

9得到select的当前选中项的text

10得到select的当前选中项的Index

11清空select的项

js 代码

// 1.判断select选项中 是否存在Value="paraValue"的Item        

function jsSelectIsExitItem(objSelect, objItemValue) {        

    var isExit = false;        

    for (var i = 0; i < objSelect.options.length; i++) {        

        if (objSelect.options[i].value == objItemValue) {        

             isExit = true;        

            break;        

         }        

     }        

    return isExit;        

}         

   

// 2.向select选项中 加入一个Item        

function jsAddItemToSelect(objSelect, objItemText, objItemValue) {        

    //判断是否存在        

    if (jsSelectIsExitItem(objSelect, objItemValue)) {        

         alert("该Item的Value值已经存在");        

     } else {        

        var varItem = new Option(objItemText, objItemValue);      

         objSelect.options.add(varItem);     

         alert("成功加入");     

     }        

}        

   

// 3.从select选项中 删除一个Item        

function jsRemoveItemFromSelect(objSelect, objItemValue) {        

    //判断是否存在        

    if (jsSelectIsExitItem(objSelect, objItemValue)) {        

        for (var i = 0; i < objSelect.options.length; i++) {        

            if (objSelect.options[i].value == objItemValue) {        

                 objSelect.options.remove(i);        

                break;        

             }        

         }        

         alert("成功删除");        

     } else {        

         alert("该select中 不存在该项");        

     }        

}    

   

   

// 4.删除select中选中的项    

function jsRemoveSelectedItemFromSelect(objSelect) {        

    var length = objSelect.options.length - 1;    

    for(var i = length; i >= 0; i--){    

        if(objSelect[i].selected == true){    

             objSelect.options[i] = null;    

         }    

     }    

}      

   

// 5.修改select选项中 value="paraValue"的text为"paraText"        

function jsUpdateItemToSelect(objSelect, objItemText, objItemValue) {        

    //判断是否存在        

    if (jsSelectIsExitItem(objSelect, objItemValue)) {        

        for (var i = 0; i < objSelect.options.length; i++) {        

            if (objSelect.options[i].value == objItemValue) {        

                 objSelect.options[i].text = objItemText;        

                break;        

             }        

         }        

         alert("成功修改");        

     } else {        

         alert("该select中 不存在该项");        

     }        

}        

   

// 6.设置select中text="paraText"的第一个Item为选中        

function jsSelectItemByValue(objSelect, objItemText) {            

    //判断是否存在        

    var isExit = false;        

    for (var i = 0; i < objSelect.options.length; i++) {        

        if (objSelect.options[i].text == objItemText) {        

             objSelect.options[i].selected = true;        

             isExit = true;        

            break;        

         }        

     }              

    //Show出结果        

    if (isExit) {        

         alert("成功选中");        

     } else {        

         alert("该select中 不存在该项");        

     }        

}        

   

// 7.设置select中value="paraValue"的Item为选中    

document.all.objSelect.value = objItemValue;    

       

// 8.得到select的当前选中项的value    

var currSelectValue = document.all.objSelect.value;    

       

// 9.得到select的当前选中项的text    

var currSelectText = document.all.objSelect.options[document.all.objSelect.selectedIndex].text;    

       

// 10.得到select的当前选中项的Index    

var currSelectIndex = document.all.objSelect.selectedIndex;    

       

// 11.清空select的项    

document.all.objSelect.options.length = 0;   

 

 

=============================================================================

<html>

<head><title>获取下拉列表选中项的值和文本(select)</title></head>

<body>

<script>

//获取下拉列表选中项的文本

function getSelectedText(name){

var obj=document.getElementById(name);

for(i=0;i<obj.length;i++){

   if(obj[i].selected==true){

    return obj[i].innerText;      //关键是通过option对象的innerText属性获取到选项文本

   }

}

}

//获取下拉列表选中项的值

function getSelectedValue(name){

var obj=document.getElementById(name);

return obj.value;      //如此简单,直接用其对象的value属性便可获取到

}

</script>

<select id="myselect">

<option value="fist">1</option>

<option value="second">2</option>

<option value="third">3</option>

</select>

<input type="button"   value="所选文本"   οnclick="alert(getSelectedText('myselect'));" />

<input type="button"   value="所选值" οnclick="alert( getSelectedValue('myselect'));" />

</body>

</html>

=============================================================================

二、获取单选按钮(radio)组的值和修改选中项

看到很多帖子里说js获取单选按钮(radio)组的值可以直接用document.getElementById("oper").value,虽然跟单选按钮组一样的下拉列表(也是列表项的数组)也是一个数组,用这种方式可以获到下拉列表的值,但是单选按钮组却获不到所选的值。仔细研究了下,总结如下:

与下拉列表不同,单选按钮须用this.form.oper或者document.getElementsByName('oper')方式获取该数组对象,document.getElementById('oper')不能获取该数组对象(select可以)。而且要获取值须通过一循环判断获取,不能直接用.value(select可以)。而要改变单选按钮组的选中项,也须用循环判断改变各个单选按钮的value。

测试代码radio.html 如下:

=============================================================================

<html>

<head></head>

<script language="javascript">

//求单选按纽的值,适用单选项及多选项。未选返回false;有选择项,返回选项值。

function getRadio(oRadio){

var oRadioLength= oRadio.length;

var oRadioValue = false;

//alert("oRadioLength:["+oRadioLength+"]");

if (oRadioLength== undefined){

      if (oRadio.checked){

       oRadioValue = oRadio.value;

      }

}else{

      for (i=0;i<oRadioLength;i++){

       //alert("oRadio["+i+"]:"+oRadio[i].checked+"/"+oRadio[i].value);

       if (oRadio[i].checked){

        oRadioValue = oRadio[i].value;

        break;

       }

      }

}

return oRadioValue;

}

//方法改进:

//求单选按纽的值,传radio名字作为参数。未选返回false;有选择项,返回选项值。

function getRadioValue(name){

var radioes = document.getElementsByName(name);

for(var i=0;i<radioes.length;i++)

{

     if(radioes[i].checked){

      return radioes[i].value;

     }

}

return false;

}

//通过值修改所选中的单选按钮

function changeRadio(oRadio,oRadioValue){        //传入一个对象

for(var i=0;i<oRadio.length;i++) //循环

{

        if(oRadio[i].value==oRadioValue) //比较值

        {

         oRadio[i].checked=true; //修改选中状态

         break; //停止循环

        }

}

}

  

//改进:

//通过值修改所选中的单选按钮

function setRadio(name,sRadioValue){        //传入radio的name和选中项的值

var oRadio = document.getElementsByName(name);

for(var i=0;i<oRadio.length;i++) //循环

{

        if(oRadio[i].value==sRadioValue) //比较值

        {

         oRadio[i].checked=true; //修改选中状态

         break; //停止循环

        }

}

}

</script>

<body>

<form name="frm">

<input type="radio" name="oper" value="agree"        >同意</td>

<input type="radio" name="oper" value="downchange" checked>下发修改</td>

<input type="radio" name="oper" value="refuse">拒保</td>

<input type="radio" name="oper" value="report" >上报 </td>

<br>

alert('result:'+getRadio(this.form.oper))

<input type="button" name="test1" value="按钮1" οnclick="alert('result:'+getRadio(this.form.oper));">       

<br>

alert('result:'+getRadio(document.getElementById('oper')))

<input type="button" name="test2" value="按钮2" οnclick="alert('result:'+getRadio(document.getElementById('oper')));">

<br>

alert(this.form.oper.value)

<input type="button" name="test3" value="按钮3" οnclick="alert(this.form.oper.value);">

<br>

changeRadio(this.form.oper,"上报")

<input type="button" name="test4" value="按钮4" οnclick="changeRadio(this.form.oper,'report');">  

<br><br><br><br>    

<select id="slt">

<option value="agree" >同意</option>

<option        value="downchange" selected>下发修改</option>

<option value="refuse">拒保</option>

<option        value="report">上报</option>

</select>

<br>

alert(this.form.slt.value)

<input type="button" name="test5" value="按钮5" οnclick="alert(this.form.slt.value);">

<br>

document.getElementById('slt')[2].innerText)

<input type="button" name="test6" value="按钮6" οnclick="alert(document.getElementById('slt')[2].innerText);">

</form>

</body>


添加 : 点击输入框时,里面的内容被全选

在输入框加个事件掉js函数就行
<input type=text οnclick="select();" value="Click">

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值