今天同学们在做Selenium的扩展,针对JQuery的某些插件,标准的click或type命令难已触发JQuery定义的一些事件,比如一个标准的type方法触发的事件如下:
由此可以看出实际上 type 命令触发的实际只有 focus,select 和 change, 远远不能满足我们的要求,而是他们写了一些新的命令来实现,我没有同意,实际上是我们没有真正弄清楚事件的触发机制,而是我找了一个页面来证实事件的触发顺序。
前面我们列出了标准的键盘事件包括以下三种:
| 属性 | 值 | 描述 |
|---|---|---|
| onkeydown | 脚本 | 当键盘被按下时执行脚本 |
| onkeypress | 脚本 | 当键盘被按下后又松开时执行脚本 |
| onkeyup | 脚本 | 当键盘被松开时执行脚本 |
以上说明已很清楚,只不过还是分情形的,通常我们要对文本框进行操作,首先要让他获得焦点,有两种方法,鼠标点击和 tab 键切换,并且无任那种方法,都事先有个 focus 事件被触发。
比如我们有两个text,我们用 tab 键切换焦点的事件顺序为:
{keydown(theTextbox - 9)} {keypress(theTextbox - 9)} {blur(theTextbox)} {focus(theTextbox1)} {select(theTextbox1)} {keyup(theTextbox1 - 9)}
这个事件序列很有意思,尤其是最后一个,keyup 发生在第二个text 上,这可是个bug 多发区。
同样的两个text, 用鼠标点击来切换焦点的事件顺序为:
{mouseout(theTextbox)} {mouseover(theTextbox1)} {mousedown(theTextbox1)} {blur(theTextbox)} {focus(theTextbox1)} {mouseup(theTextbox1)} {click(theTextbox1)}
这个事件序列还比较正常,没什么特殊之处。
在切换焦点之后的每一次键入都会触发这三个键盘事件,比如按下m键触发的事件有:
{keydown(theTextbox1 - 77)} {keypress(theTextbox1)} {keyup(theTextbox1 - 77)}
此时如果单击鼠标,则触发以下事件
{mouseover(theTextbox1)} {mousedown(theTextbox1)} {mouseup(theTextbox1)} {click(theTextbox1)} {mouseout(theTextbox1)}
在完成输入,把焦点切换到其他元素时,这时发生在 text 的事件有两个:
{change(theTextbox1)} {blur(theTextbox1)}
这就是一个在文本框输入内容时的一个完整的事件机制,所以大家在开发,编写测试工具时得注意,千万不要多做事情,但更不能不做。
所以建议type的实现方式更改如下:
此方法将持续改进,希望能真实的模拟用户的输入。

本文探讨了Selenium在处理JQuery插件时遇到的问题,即标准的click和type命令无法完全触发JQuery定义的所有事件。通过分析标准的type命令触发的事件,对比实际需求,介绍了键盘事件的触发机制及文本框操作时的完整事件流程。
5739

被折叠的 条评论
为什么被折叠?



