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

javascript操作select元素一例

2015-03-26 16:37 344 查看
熟悉一下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;
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: