用js给select插入option

用js给select插入option,第1张

1、使用innerHTML

<script>

var shosetype=document.createElement("select") //创建select标签   

shosetype.setAttribute("id","sc")//设置select的id为“sc"

document.body.appendChild(shosetype)//将select添加到body

var option="<option value=\"1\">添加成功</option>"//新建options

shosetype.innerHTML=option//将option添加到select

</script>

2、options.add

//根据select查找对象, 

var obj=document.getElementById('mySelect') //获取到id为'mySelect'的select元素

//添加一个选项 

obj.add(new Option("文本","值")) //添加select的options  这个只能在IE中有效 

obj.options.add(new Option("text","value")) //添加select的options  这个兼容IE与firefox

按下列排版输入下列代码:

if (data) {

var jsonObject = eval(data.Table)

var selectSecond = $("#SelectSecond")

selectSecond.empty()

for (var i = 0 i < jsonObject.length i++) {

var Opt = new Option()

//var Opt = document.createElement("option")

Opt.value = jsonObject[i].numbers

Opt.Text = jsonObject[i].notects

selectSecond.options.add(Opt)

}

在前端

<select id="SelectSecond" onchange="selected()">

</select>

但是样没有反应,下拉框是空白的。jsonObject确实是有值的。

更多0

关于 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/htmlcharset=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/htmlcharset=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>


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11672900.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存