您的位置:首页 > Web前端 > JavaScript

JS对select动态添加options操作

2014-12-26 16:27 525 查看
<select id="ddlResourceType" onchange="getvalue(this)">

</select>

    动态删除select中的所有options: 

       document.getElementById("ddlResourceType").options.length=0; 

     动态删除select中的某一项option: 

       document.getElementById("ddlResourceType").options.remove(indx);  

     动态添加select中的项option: 

       document.getElementById("ddlResourceType").options.add(new Option(text,value)); 

     上面在IE和FireFox都能测试成功,希望以后你可以用上。 

其实用标准的DOM操作也可以,就是document.createElement,appendChild,removeChild之类的。 

取值方面

    function getvalue(obj)

    {

        var m=obj.options[obj.selectedIndex].value

        alert(m);//获取value

        var n=obj.options[obj.selectedIndex].text

        alert(n);//获取文本

    }

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

1 检测是否有选中 

if (objSelect.selectedIndex > - 1 ) { 

// 说明选中 

} else { 

// 说明没有选中 



2 删除被选中的项 

objSelect.options[objSelect.selectedIndex] = null ; 

3 增加项 

objSelect.options[objSelect.length] = new Option( " 你好 " , " hello " ); 

4 修改所选择中的项 

objSelect.options[objSelect.selectedIndex] = new Option( " 你好 " , " hello " ); 

5 得到所选择项的文本 

objSelect.options[objSelect.selectedIndex].text; 

6 得到所选择项的值 

objSelect.options[objSelect.selectedIndex].value;

 

总结:document.getElementById("元素ID")与jquery中的$("#元素ID")是不等同的,应该用$("#元素ID").get(0)。 get()方法为取得所有匹配的 DOM(document) 元素集合。可用以下方法测试:

<div id="SAL"></div>

alert($("#SAL"));  弹出对话框内容为[object,Object]

alert($("#SAL").get(0));  弹出对话框内容为[object,HTMLDivElement]

alert(document.getElementById("SAL"));  弹出对话框内容为[object,HTMLDivElement]

注意:请在FireFox浏览器下进行测式,否则看不到这些变化!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  select