javascript操作select元素一例

来源:互联网 发布:手机画设计图软件 编辑:程序博客网 时间:2024/05/14 20:06

熟悉一下js对select元素的操作,html页面中建立一个form,其中包含一个select元素和submit按钮。
当选择select中某一项时改变其文字,当select中所有项的文字都改变后,重新恢复它们。
当按下submit时关闭窗口本身,代码如下:

<!DOCTYPE html><html><head><title>duang for select elements</title><script type="text/javascript">    function do_change(elt){        var text = elt[elt.selectedIndex].innerHTML;        if(!text.match(/\[/))            elt[elt.selectedIndex].innerHTML += " [duang]";        var is_all_seleted = true;        for(var i=0;i<elt.length;++i){            if(!elt[i].innerHTML.match(/\[/)){                is_all_seleted = false;                break;            }        }        if(is_all_seleted){            alert("all duang!!!\nand reset it!!!");            for(var i=0;i<elt.length;++i){                elt[i].innerHTML = elt[i].innerHTML.replace(/\s\[.*\]/,"")            }        }    }</script></head><body>    <form id="frm_main" action="#" method="post">        <select id="slt" onchange="do_change(this);">            <option value="opt_1">opt A</option>            <option value="opt_2">opt B</option>            <option value="opt_3">opt C</option>            <option value="opt_4">opt D</option>            <option value="opt_5">opt E</option>        </select>        <input type="submit" value="close window" onclick="window.close();" />    </form></body></html>

在firefox中一开始貌似无法关闭窗口本身,后来发现在about:config中设置dom.allow_scripts_to_close_windows为true即可。
如果每个select中的选项变化没有规律,则可以写一个on_change_ex来处理,代码如下:

function do_change_ex(me){        var text = me[me.selectedIndex].innerHTML;        if(!text.match(/\[/)){            me[me.selectedIndex].text_bak = me[me.selectedIndex].innerHTML;            me[me.selectedIndex].innerHTML += " [duang]";            me[me.selectedIndex].is_changed = true;        }        var is_all_seleted = true;        for(var i=0;i<me.length;++i){            if(!me[i].is_changed){                is_all_seleted = false;                break;            }        }        if(is_all_seleted){            alert("all duang!!!\nand reset it!!!");            for(var i=0;i<me.length;++i){                me[i].innerHTML = me[i].text_bak;                me[i].is_changed = false;            }        }    }
0 0