javascript操作select元素实例分析
本文实例讲述了javascript操作select元素的用法。分享给大家供大家参考。具体分析如下:
这里熟悉一下js对select元素的操作,html页面中建立一个form,其中包含一个select元素和submit按钮。
当选择select中某一项时改变其文字,当select中所有项的文字都改变后,重新恢复它们。
当按下submit时关闭窗口本身,代码如下:
<!DOCTYPEhtml>
<html>
<head>
<title>duangforselectelements</title>
<scripttype="text/javascript">
functiondo_change(elt){
vartext=elt[elt.selectedIndex].innerHTML;
if(!text.match(/\[/))
elt[elt.selectedIndex].innerHTML+="[duang]";
varis_all_seleted=true;
for(vari=0;i<elt.length;++i){
if(!elt[i].innerHTML.match(/\[/)){
is_all_seleted=false;
break;
}
}
if(is_all_seleted){
alert("allduang!!!\nandresetit!!!");
for(vari=0;i<elt.length;++i){
elt[i].innerHTML=elt[i].innerHTML.replace(/\s\[.*\]/,"")
}
}
}
</script>
</head>
<body>
<formid="frm_main"action="#"method="post">
<selectid="slt"onchange="do_change(this);">
<optionvalue="opt_1">optA</option>
<optionvalue="opt_2">optB</option>
<optionvalue="opt_3">optC</option>
<optionvalue="opt_4">optD</option>
<optionvalue="opt_5">optE</option>
</select>
<inputtype="submit"value="closewindow"onclick="window.close();"/>
</form>
</body>
</html>
在firefox中一开始貌似无法关闭窗口本身,后来发现在about:config中设置dom.allow_scripts_to_close_windows为true即可。
如果每个select中的选项变化没有规律,则可以写一个on_change_ex来处理,代码如下:
functiondo_change_ex(me){
vartext=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;
}
varis_all_seleted=true;
for(vari=0;i<me.length;++i){
if(!me[i].is_changed){
is_all_seleted=false;
break;
}
}
if(is_all_seleted){
alert("allduang!!!\nandresetit!!!");
for(vari=0;i<me.length;++i){
me[i].innerHTML=me[i].text_bak;
me[i].is_changed=false;
}
}
}
希望本文所述对大家的javascript程序设计有所帮助。