JS动态创建select 操作select和option

1.动态创建select

    function createSelect(){  
              var mySelect = document.createElement("select");  
              mySelect.id = "mySelect";   
              document.body.appendChild(mySelect);  
          }  

2.添加选项option

function addOption(){  
  
         //根据id查找对象,  
          var obj=document.getElementById('mySelect');  
  
          //添加一个选项  
          obj.add(new Option("文本","值"));    //这个只能在IE中有效  
          obj.options.add(new Option("text","value")); //这个兼容IE与firefox  
    } 

3.删除所有选项option   

function removeAll(){  
         var obj=document.getElementById('mySelect');  
         obj.options.length=0;  
  
   } 

4.删除一个选项option

    function removeOne(){  
               var obj=document.getElementById('mySelect');  
      
               //index,要删除选项的序号,这里取当前选中选项的序号  
               var index=obj.selectedIndex;  
               obj.options.remove(index);  
         }  

5.获得选项option的值

    var obj=document.getElementById('mySelect');  
      
    var index=obj.selectedIndex; //序号,取当前选中选项的序号  
      
    var val = obj.options[index].value;  

6.获得选项option的文本

    var obj=document.getElementById('mySelect');  
      
    var index=obj.selectedIndex; //序号,取当前选中选项的序号  
      
    var val = obj.options[index].text;  

7.修改选项option

    var obj=document.getElementById('mySelect');  
      
    var index=obj.selectedIndex; //序号,取当前选中选项的序号  
      
    var val = obj.options[index]=new Option("新文本","新值");  

8.删除select     

function removeSelect(){  
            var mySelect = document.getElementById("mySelect");  
mySelect.parentNode.removeChild(mySelect);  
     } 

整个实例的完整代码如下:

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//ZH-CN" "http://www.w3.org/TR/html4/strict.dtd">  
    <html>  
    <head>  
       <meta http-equiv="Content-Type" content="text/html">  
    <head>  
       <script language=JavaScript>  
        function $(id)  
        {  
         return document.getElementById(id)  
        }  
        function show()  
        {  
         var selectObj=$("area")  
         var myOption=document.createElement("option")  
         myOption.setAttribute("value","10")  
         myOption.appendChild(document.createTextNode("上海"))  
         var myOption1=document.createElement("option")  
         myOption1.setAttribute("value","100")  
         myOption1.appendChild(document.createTextNode("南京"))  
         selectObj.appendChild(myOption)  
         selectObj.appendChild(myOption1)  
        }  
        function choice()  
        {  
         var index=$("area").selectedIndex;  
         var val=$("area").options[index].getAttribute("value")  
         if(val==10)  
         {  
          var i=$("context").childNodes.length-1;  
         var remobj=$("context").childNodes[i];  
         remobj.removeNode(true)  
          var sh=document.createElement("select")  
          sh.add(new Option("浦东新区","101"))  
          sh.add(new Option("黄浦区","102"))  
          sh.add(new Option("徐汇区","103"))  
          sh.add(new Option("普陀区","104"))  
          $("context").appendChild(sh)  
         }  
         if(val==100)  
         {  
          var i=$("context").childNodes.length-1;  
         var remobj=$("context").childNodes[i];  
         remobj.removeNode(true)  
          var nj=document.createElement("select")  
          nj.add(new Option("玄武区","201"))  
          nj.add(new Option("白下区","202"))  
          nj.add(new Option("下关区","203"))  
          nj.add(new Option("栖霞区","204"))  
          $("context").appendChild(nj)  
         }  
        }  
        function calc()  
        {  
         var x=$("context").childNodes.length-1;  
         alert(x)  
        }  
        function remove()  
        {  
         var i=$("context").childNodes.length-1;  
         var remobj=$("context").childNodes[i];  
         remobj.removeNode(true)  
        }  
       </script>  
    <body>  
    <div id="context">  
       <select id="area" οnchange="choice()">  
       </select>  
    </div>  
    <input type=button value="显示" οnclick="show()">  
    <input type=button value="计算结点" οnclick="calc()">  
    <input type=button value="删除" οnclick="remove()">  
    </body>  
    </html>  

改进版:在select中添加、修改、删除option元素

    function watch_ini(){ // 初始  
    for(var i=0; i<arguments.length; i++){  
    var word = document.createElement("OPTION");  
    word.text = arguments[i];  
    watch.keywords.add(word); // watch. is form name  
    }  
    }  
    function watch_add(f){ // 增加  
    var word = document.createElement("OPTION");  
    word.text = f.word.value;  
    f.keywords.add(word);   
    }  
    但上述 add() 方法只在IE下有效,为兼容FF和Opera,对上述代码进行了一下改进,改动后代码如下: function watch_ini(){ // 初始  
    for(var i=0; i<arguments.length; i++){  
       var oOption=new Option(arguments[i],arguments[i]);  
       document.getElementById("MySelect")[i]=oOption;  
    }  
    }  
    function watch_add(f){ // 增加  
       var oOption=new Option(f.word.value,f.word.value);  
       f.keywords[f.keywords.length]=oOption;  
    }  

整个实例的完整代码如下:

    <!doctype html public "-//w3c//dtd html 4.0 transitional//en">  
    <html>  
    <head>  
    <title>javascript select options text value</title>  
    <meta name="keywords" content="javascript select options text value add modify delete set">  
    <meta name="description" content="javascript select options text value add modify delete set">  
    <script language="javascript">  
    <!--  
    function watch_ini(){ // 初始  
    for(var i=0; i<arguments.length; i++){  
       var oOption=new Option(arguments[i],arguments[i]);  
       document.getElementById("MySelect")[i]=oOption;  
    }  
    }  
    function watch_add(f){ // 增加  
       var oOption=new Option(f.word.value,f.word.value);  
       f.keywords[f.keywords.length]=oOption;  
    }  
    function watch_sel(f){ // 编辑  
    f.word.value = f.keywords[f.keywords.selectedIndex].text;  
    }  
    function watch_mod(f){ // 修改  
    f.keywords[f.keywords.selectedIndex].text = f.word.value;  
    }  
    function watch_del(f){ // 删除  
    f.keywords.remove(f.keywords.selectedIndex);  
    }  
    function watch_set(f){ // 保存  
    var set = "";  
    for(var i=0; i<f.keywords.length; i++){  
    set += f.keywords[i].text + ";";  
    }  
    confirm(set);  
    }  
    //-->  
    </script>  
    </head>  
    <body>  
    <form name="watch" method="post" action="">  
    <select id="MySelect" name="keywords" size="10" οnchange="watch_sel(this.form)"></select><br>  
    <script language="javascript">  
    <!--  
    watch_ini("我","你","妳","他","她","它","尔"); // 初始关键词  
    //-->  
    </script>  
    <input type="text" name="word" /><br />  
    <input type="button" value="增加" οnclick="watch_add(this.form);" />  
    <input type="button" value="修改" οnclick="watch_mod(this.form);" />  
    <input type="button" value="删除" οnclick="watch_del(this.form);" />  
    <input type="button" value="保存" οnclick="watch_set(this.form);" />  
    </form>  

用一个字符串创建一个数组方法:

<script language="javascript">     
  
function spli(){   
  
datastr="2,2,3,5,6,6";        
  
var str= new Array();      
  
   str=datastr.split(",");        
  
 for (i=0;i<str.length ;i++ )     
  
  { document.write(str[i]+"<br/>");  }     
  
}     
  
spli();     
  
</script> 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这个问题是关于JavaScript中添加表单下拉框选项(option)的。 在JavaScript中,可以通过以下代码动态地向表单下拉框添加选项: ``` var select = document.getElementById("mySelect"); // 获取下拉框元素 var option = document.createElement("option"); // 创建一个<option>元素 option.text = "选项文本"; // 设置选项文本 option.value = "选项值"; // 设置选项值(可选) select.add(option); // 把选项添加到下拉框中 ``` 其中,`mySelect`是要添加选项的下拉框元素的ID,可以根据实际情况修改。 希望对您有所帮助! ### 回答2: 在JavaScript中,我们可以通过select元素的options属性来访问它的选项。此属性返回表示选项列表的HTMLCollection对象。我们可以使用appendChild()方法将动态创建的新option元素添加到选项列表末尾或insertBefore()方法将其插入到选项列表中的指定位置。但要注意的是,我们必须先创建一个新的option元素,再把它添加到select元素的options集合中。下面是一些示例代码: 1. 在select元素末尾添加新的option ```javascript var select = document.getElementById("mySelect"); var option = document.createElement("option"); option.text = "新的选项"; select.options.add(option); ``` 2. 在select元素中指定位置添加新的option ```javascript var select = document.getElementById("mySelect"); var option = document.createElement("option"); option.text = "新的选项"; // 将新的option插入到select元素的第二个位置 select.options.add(option, 1); ``` 除了使用appendChild()方法和insertBefore()方法添加新的option元素外,我们还可以设置新option元素的属性,如value、selected和disabled等。请注意,有些浏览器可能无法正确处理动态创建select选项,在这种情况下,我们可以使用innerHTML属性更改整个选项列表的HTML代码。但是,这种方法可能会破坏与选项列表相关联的JavaScript代码,因此请谨慎使用。 ### 回答3: JavaScriptselect 元素提供了一种很方便的方式来创建下拉菜单。通常情况下,select 里面的 option 对象是通过静态的方式创建的,即在 HTML 中手工编写。 但是,在某些情况下,我们需要通过 JavaScript 动态地添加 option 对象来实现更加复杂的操作。这时可以通过代码中的 add 方法来实现。 添加 select option 方法: 首先,我们需要调用 select 元素的 options 属性,获取 select 对象的 option 集合。options 属性是一个数组,包含了当前 select 元素中所有 option 对象,可以通过数组下标的方式访问每个 option 对象。 其次,我们需要创建一个 option 对象,并设置 option 对象的 value 和 text 属性。value 属性表示该 option 对象的值,text 属性表示该 option 对象在下拉菜单中的显示文本。 最后,我们将创建option 对象添加到 select 元素的 options 集合中,即可完成动态添加 option 对象的操作。 代码如下: ``` <script type="text/javascript"> //获取 select 对象 var selectObj = document.getElementById("selectId"); //创建一个 option 对象 var optionObj = document.createElement("option"); //设置 option 对象的 value 和 text 属性 optionObj.value = "value1"; optionObj.text = "Option 1"; //将 option 对象添加到 select 对象的 options 集合中 selectObj.options.add(optionObj); </script> ``` 这样,我们就可以通过 JavaScript 动态地添加 selectoption 对象了。在实际的应用场景中,我们可以根据具体的需求,修改代码逻辑,实现更加丰富的操作

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值