js实现select动态添加option

 

关于 select 的添加 option 应该注意的问题。 
标准的做法如上
也就是说,标准的做法是 s.options.add();
但是如果你一定要用 s.appendChild(option);
注意了,你只能用如下两种方式之一:
1.  
     s.appendChild(option);
     option.text = 'hello world';
     option.value =3;
   也就是,一定要先添加到 select 中,然后再为 option 赋值。否则在 FF 下是显示正常的,但是在 IE6 中显示的是空白
 
2. 如果你要讲 option.text 和 option.value 的赋值放在前面,那么请用 option.innerHTML 而不是 option.text
  如下: 
    option.innerHTML = 'hello world';
    opion.value = 3;
    option.appendChild(option);
3 第三种解决方式。
var op=document.createElement("option");      // 新建OPTION (op) 
op.setAttribute("value",0);          // 设置OPTION的 VALUE 
op.appendChild(document.createTextNode("请选择---")); // 设置OPTION的 TEXT
select.appendChild(op);           // 为SELECT 新建一 OPTION(op)

select.options.length=0;           //把select对象的所有option清除掉

select.options.remove(i);           //把select对象的第i个option清除掉


 <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>JS动态添加删除option</title>
<script>
//动态删除select中的所有options:
function delAllOptions(){
      document.getElementById("user_dm").options.length=0;
}
//动态删除select中的某一项option:
function delOneOption(indx){
      document.getElementById("user_dm").options.remove(indx);
}

// 动态添加select中的项option:
function addOneOption(){
      //document.getElementById("user_dm").options.add(new Option(2,"mytest"));
  
   var selectObj=document.getElementById("user_dm");
   alert(selectObj.length);
   selectObj.options[selectObj.length] = new Option("mytest", "2");
}
</script>
</head>
<body>
<select id="user_dm" name="user_dm">
<option value="0" selecte>==请选择人员==</option>
<option value="1">test</option>
</select><br>
<input type="button" onClick="addOneOption()" value="添加">
<input type="button" onClick="delOneOption(1)" value="删除第一个">
<input type="button" onClick="delAllOptions()" value="清空">
</body>
</html>

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

 <html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title>Js动态添加与删除Option对象</TITLE>

<script language="JavaScript">

// 添加选项

function addOption(pos){

var objSelect=document.getElementById("mySelect");

    // 取得字段值

   //var strName = document.myForm.myOptionName.value;

    // var strValue = document.myForm.myOptionValue.value;

    // 建立Option对象

    var objOption = new Option("李高灰","bbbbbbbbb");

    if (pos == -1&& pos > objSelect.options.length))

       objSelect.options[objSelect.options.length] = objOption;

    else

       objSelect.add(objOption, pos);

}

 

 

// 删除

function deleteOption(type){

var objSelect=document.getElementById("mySelect");

    if (type == true)

       objSelect.options[objSelect.selectedIndex] = null;

    else

       objSelect.remove(objSelect.selectedIndex);

}

// 显示选项信息

function showOption(){

var objSelect=document.getElementById("mySelect");

    var name = objSelect.options[objSelect.selectedIndex].text;

    var value = objSelect.options[objSelect.selectedIndex].value;

    alert(name + " = " + value);

}

 

//动态删除select中的所有options:

function clearAllOptions(){

   var objSelect=document.getElementById("mySelect");

   objSelect.options.length=0;

}

</script>

 

  • 1
    点赞
  • 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元素的属性,如valueselected和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、付费专栏及课程。

余额充值