javascript实现两个下拉框的关联

最近在开发和维护一个后台测试系统,专门针对KVM和Xen的patch进行自动化测试,基本功能已经可以正常工作了,这一个月左右的工作可以暂告一段落。Patch测试系统的前台UI是一个网页,让用户(developer)去提交KVM、Xen、Linux、QEMU的patch,然后系统会自动测试,将结果发给developer。今天在对该系统进行简单测试时,发现一个问题,就是我们定义了几个测试场景(scenario),系统中总共有几台机器(test box)供测试,但是有的场景必须在其中1台或两台上测试,而后台自动调度系统还不完善,自动调度不好用,如果选择自动调度机器去测试则会出现测试场景和机器不匹配的情况。当然做一个后台的比较智能的测试调度器也是我明年考虑做的一个东西。而作为临时解决问题且效果较好的做法是,在选择测试场景的下拉列表时,自动关联测试机器的下拉列表,所以今天花了几乎一整天的时间用javascript来做了这个事情(JS大牛会笑话我的,可惜我对JS不熟,实现代码和测试功能时也遇到各种bug)。
首先,看一下patch测试系统的基本界面吧。
patch test system

用javascript实现了其中两个下拉框的关联(test scenario 和 test box)。我在实现的过程中,尽量做到代码干净优雅,将javascript和html代码分离,且在html中的元素避免使用“onclink”、“onchange”等方法。在HTML中只需要有一段引入javascript文件的代码即可,如下:

贴一下我实现的javascript的代码(option-association.js)吧,一天的心血啊。自己做的过程中遇到的较大的bug有:1. IE、Firefox对attachEvent、addEventListener方法的支持不同; 2. 清空下拉列表时,最初我写的代码是有bug的,有部分元素未被清空。

参考资料:
(js与html的分离)http://www.cnblogs.com/Fskjb/archive/2010/02/26/1674559.html
(js与html的分离)http://blog.csdn.net/eengel/article/details/6193209
(Firebug调试js)http://www.blogjava.net/vincent/archive/2009/04/14/265591.html
(借鉴了aeoril的回答)http://stackoverflow.com/questions/12572404/attachevent-cant-use-this-javascript
w3schools依然是学习html、javascript、CSS、XML、PHP、JQuery等Web技术应该参考的网站。
http://www.w3schools.com/jsref/dom_obj_event.asp
http://www.w3schools.com/html/html_forms.asp

master

Stay hungry, stay foolish.

2 Comments

  1. 请问下 , 针对KVM和Xen的patch进行自动化测试, 测试什么内容呢?学习下您的思路。

    • 测试内容,包括基本的多种类型客户机的启动、CPU和内存数量分配、网络通畅检查、电源管理方面的、VT-d、SR-IOV等,还有一些硬件平台引入的新功能,在Xen、KVM中的实现是否正常工作。我还有其他测试系统测试一些性能、压力方面的。

发表评论

电子邮件地址不会被公开。 必填项已用*标注