通过添加user-extension.js解决selenium-IDE中的回车和blank问题

通过添加user-extension.js解决录制回车问题


1. 编写user-extension.js(文件名可以随便取),录制回车的js代码如下:

Recorder.removeEventHandler('keyDown');

Recorder.addEventHandler('keyDown', 'keydown', function(event) {

var keynum;

if(window.event) // IE

{

keynum = event.keyCode

}

else if(event.which) // netscape/Firefox/Opera

{

keynum = event.which

}

if(keynum==13){

var _this = this;

var target = _this.findLocator(event.target);

setTimeout(function(){_this.record('keyDown', target,'\\'+keynum); },1000);//延迟1000ms再写入回车记录

}

}, { capture: true });

2. 添加脚本到IDE中(option-IDE extensions):

3. 脚本将keydown事件绑定到Selenium系统命令keyDown,并判断按键是否为13(回车),如果是就在IDE中写入一条命令,写入命令使用this.record('keyDown', this.findLocator(event.target),'\\'+keynum);,其中第一个参数是IDE中的Command列,第二个参数为Target列,第三个参数为Value列。{ capture: true }表示录制。

4. 系统命令:在command中可以查到。

5. 其他:可在火狐浏览器中输入地址:

chrome://selenium-ide/content/recorder-handlers.js查看click的系统事件。


通过添加user-extension.js解决blank跳转问题


1. 问题描述:

在使用Selenium-IDE录制时,如果录制页面有新开页,回放脚本的时候会报警告<a href="xxx.jsp" target="_blank">,并且会在新窗口打开页面,但由于无法判断新窗口的id,所以无法继续执行脚本中的其他命令。

2. 解决思路:

将原先的click命令替换成open并将href中的值取出付给open的target。这样可保证在本页面打卡,并可正常执行剩下的脚本命令。

3. 脚本代码:将如下代码写入user-extension.js中,并添加

option-IDE extensions。

Recorder.removeEventHandler('clickLocator');

Recorder.addEventHandler('clickLocator', 'click', function(event) {

if (event.button == 0) {

var clickable = this.findClickableElement(event.target);

var href = event.target.getAttribute("href");//event.target是html标签对象

var blank = event.target.getAttribute("target");

if (clickable) {

if (this.mouSEOverLocator) {

this.record('mouSEOver', this.mouSEOverLocator, '');

delete this.mouSEOverLocator;

}

if(blank!=null&&blank.indexOf("blank")>=0){

this.record("waitForElementPresent", this.findLocators(event.target), '');//等待元素加载完成

this.record("open", href, '');

}

else{

this.record("click", this.findLocators(event.target), '');

}

} else {

var target = event.target;

if(blank!=null&&blank.indexOf("blank")>=0){

this.record("waitForElementPresent", this.findLocators(event.target), '');

this.record("open", href, '');

}

else{

this.callIfMeaningfulEvent(function() {

this.record("click", this.findLocators(target), '');

});

}

}

}

}, { capture: true });

注意:回放时为保证脚本正确执行,最好将回放速度调整为slow,否则页面若未加载完成,可能导致有些命令执行失败。



相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...