JavaScript操作Select元素说来也不是什么高深技术,不过在网页中还是很有用的。
今天试着用面向对象的思想用javascript写了一个SelectUtil“类”,完成网页中的select元素的各种操作,包括:添加、删除选中、全部删除、移动、调整顺序、全选。
代码本身没有什么好说的,估计很多人都会。只是写代码、调试代码的时候,发现两个有趣的现象:
1.FireFox可以直接把一个select元素的option对象插入另一个select元素,实际的效果是移动;而IE中同样的操作会出错;
2.同样的脚本,写在表单里与不写在表单里竟然有很大的差别,这个我以前没有注意到。
JavaScript操作Select元素,网页运行的效果:
JavaScript操作Select元素的代码如下:
复制
< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> < html xmlns="http://www.w3.org/1999/xhtml"> < head> < meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> < title>listbox控制测试< /title> < script type="text/javascript"> function SelectUtil(idOrObj){ if(typeof(idOrObj)=="string"){ this.selectObj=document.getElementById(idOrObj); } else if (idOrObj!=null && typeof(idOrObj)=="object" && idOrObj.tagName=="SELECT"){ this.selectObj=idOrObj; } else{ alert("创建对象失败,参数不合法!"); } } SelectUtil.prototype.isExist=function(itemValue){ var isExist = false; for(var i=0; i< this.selectObj.options.length; i++){ if(this.selectObj.options[i].value==itemValue){ isExist=true; break; } } return isExist; } SelectUtil.prototype.addItem=function(itemText,itemValue){ if(!itemText || !itemValue || typeof(itemText)!="string" ||typeof(itemValue)!="string" )return false; if(this.isExist(itemValue)){ //alert("项目已存在!"); return false; } var optionItem = new Option(itemText,itemValue); this.selectObj.options.add(optionItem); return true; } SelectUtil.prototype.delItem=function(itemValue){ var bDel=false; for(var i=0; i< this.selectObj.options.length; i++){ if(this.selectObj.options[i].value==itemValue){ bDel=true; this.selectObj.options.remove(i); break; } } return bDel; } SelectUtil.prototype.delSelectedItem=function(){ var length = this.selectObj.options.length-1; var num = 0; for(var i=length; i>=0; i--){ if(this.selectObj.options[i].selected==true){ this.selectObj.options[i] = null; num++; } } return num; } SelectUtil.prototype.cloneItem = function (itemValue){ var result=null; for(var i=0; i< this.selectObj.options.length; i++){ if(this.selectObj.options[i].value==itemValue){ result=this.selectObj.options[i]; break; } } if(result==null)return null; return new Option(result.text,result.value); } SelectUtil.prototype.getItem = function (itemValue){ var result=null; for(var i=0; i< this.selectObj.options.length; i++){ if(this.selectObj.options[i].value==itemValue){ result=this.selectObj.options[i]; break; } } return result; } SelectUtil.prototype.modItemText=function(itemText,itemValue){ var opt=this.getItem(itemValue); if(opt==null){ alert("没有找到指定的项目!"); return false; } else{ opt.text = itemText; return true; } } SelectUtil.prototype.selItemByValue=function(itemValue){ var opt = this.getItem(itemValue); if(opt!=null){ opt.selected=true; return true; } else{ return false; } } SelectUtil.prototype.clear=function(){ this.selectObj.options.length=0; } SelectUtil.prototype.selectedIndex=function(){ return this.selectObj.selectedIndex; } SelectUtil.prototype.seletedText=function(){ return this.selectObj.text; } SelectUtil.prototype.getSelectedItem=function(){ var idx = this.selectObj.selectedIndex; if(idx==-1)return null; else{ return this.selectObj.options[idx]; } } SelectUtil.prototype.adjustItem=function(optionObj,direction){ if(!optionObj){ optionObj = this.getSelectedItem(); } if(!optionObj)return false; var delta = (direction=="down")?1:-1; if(optionObj.index+delta< 0 || optionObj.index+delta>=this.selectObj.options.length)return true; else{ var opt,tmp; opt = this.selectObj.options[optionObj.index+delta]; tmp = opt.value; opt.value=optionObj.value; optionObj.value = tmp; tmp = opt.text; opt.text=optionObj.text; optionObj.text = tmp; opt.selected=true; optionObj.selected=false; return true; } } SelectUtil.prototype.getAllItem=function(){ return this.selectObj.options; } SelectUtil.prototype.getItemCount=function(){ return this.selectObj.options.length; } SelectUtil.prototype.moveSelectedItemTo=function(anotherSelectObj){ if(!anotherSelectObj)return false; var length = this.selectObj.options.length-1; var num = 0,opt; for(var i=length; i>=0; i--){ if(this.selectObj.options[i].selected==true){ num++; opt = this.selectObj.options[i]; //没有验证有无重复 anotherSelectObj.options.add(new Option(opt.text,opt.value)); this.selectObj.options[i] = null; } } return num; } SelectUtil.prototype.moveAllItemTo=function(anotherSelectObj,bCreate){ if(!anotherSelectObj)return false; var length = this.selectObj.options.length-1; var num = 0,opt=null; for(var i=length; i>=0; i--){ num++; opt = this.selectObj.options[i]; //没有验证有无重复 anotherSelectObj.options.add(new Option(opt.text,opt.value)); this.selectObj.options[i] = null; } return num; } SelectUtil.prototype.getObject=function(){ return this.selectObj; } SelectUtil.prototype.selectAll=function(){ for(var i=0; i< this.selectObj.options.length; i++){ this.selectObj.options[i].selected=true; } } < /script> < style type="text/css"> #srclb,#dstlb{ border:1px solid #aaa; width:200px; height:400px; } .zhcxbtn{ width:30px; } < /style> < /head> < body> < div> < table width="460" border="0" class="zhcx" cellpadding="0" cellspacing="0"> < tr> < td> < select multiple="multiple" name="srclb" id="srclb" ondblclick="srclb.moveSelectedItemTo(dstlb.getObject());"> < option value="1">宝马1< /option> < option value="2">宝马2< /option> < option value="3">宝马3< /option> < option value="4">宝马4< /option> < option value="5">宝马5< /option> < option value="6">宝马6< /option> < option value="7">宝马7< /option> < /select> < /td> < td> < input type="button" class="zhcxbtn" value=">" onclick="srclb.moveSelectedItemTo(dstlb.getObject());"/> < input type="button" class="zhcxbtn" value=">>" onclick="srclb.moveAllItemTo(dstlb.getObject());"/> < input type="button" class="zhcxbtn" value="< " onclick="dstlb.moveSelectedItemTo(srclb.getObject());"/> < input type="button" class="zhcxbtn" value="< < " onclick="dstlb.moveAllItemTo(srclb.getObject());"/> < /td> < td> < select multiple="multiple" name="dstlb" id="dstlb" ondblclick="dstlb.adjustItem();"> < /select> < /td> < td> < input type="button" class="zhcxbtn" value="↑" onclick="dstlb.adjustItem();"/> < input type="button" class="zhcxbtn" value="↓" onclick="dstlb.adjustItem(null,'down');"/> < /td> < /tr> < /table> < /div> < input type="button" value="全选" onclick="dstlb.selectAll();"/> < script type="text/javascript"> var dstlb = new SelectUtil("dstlb"); var srclb = new SelectUtil("srclb"); < /script> < /body> < /html>
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
120.
121.
122.
123.
124.
125.
126.
127.
128.
129.
130.
131.
132.
133.
134.
135.
136.
137.
138.
139.
140.
141.
142.
143.
144.
145.
146.
147.
148.
149.
150.
151.
152.
153.
154.
155.
156.
157.
158.
159.
160.
161.
162.
163.
164.
165.
166.
167.
168.
169.
170.
171.
172.
173.
174.
175.
176.
177.
178.
179.
180.
181.
182.
183.
184.
185.
186.
187.
188.
189.
190.
191.
192.
193.
194.
195.
196.
197.
198.
199.
200.
201.
202.
203.
204.
205.
206.
207.
208.
209.
210.
211.
212.
213.
214.
215.
216.
217.
218.
219.
220.
221.
222.
223.
224.
225.
226.
227.
228.
229.
230.
231.
232.
233.
【编辑推荐】