您好,登錄后才能下訂單哦!
通過(guò)添加user-extension.js解決錄制回車問(wèn)題
1. 編寫user-extension.js(文件名可以隨便?。浿苹剀嚨?/span>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系統(tǒng)命令keyDown,并判斷按鍵是否為13(回車),如果是就在IDE中寫入一條命令,寫入命令使用this.record('keyDown', this.findLocator(event.target),'\\'+keynum);,其中第一個(gè)參數(shù)是IDE中的Command列,第二個(gè)參數(shù)為Target列,第三個(gè)參數(shù)為Value列。{ capture: true }表示錄制。
4. 系統(tǒng)命令:在command中可以查到。
5. 其他:可在火狐瀏覽器中輸入地址:
chrome://selenium-ide/content/recorder-handlers.js查看click的系統(tǒng)事件。
通過(guò)添加user-extension.js解決blank跳轉(zhuǎn)問(wèn)題
1. 問(wèn)題描述:
在使用Selenium-IDE錄制時(shí),如果錄制頁(yè)面有新開(kāi)頁(yè),回放腳本的時(shí)候會(huì)報(bào)警告<a href="xxx.jsp" target="_blank">,并且會(huì)在新窗口打開(kāi)頁(yè)面,但由于無(wú)法判斷新窗口的id,所以無(wú)法繼續(xù)執(zhí)行腳本中的其他命令。
2. 解決思路:
將原先的click命令替換成open并將href中的值取出付給open的target。這樣可保證在本頁(yè)面打卡,并可正常執(zhí)行剩下的腳本命令。
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標(biāo)簽對(duì)象
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 });
注意:回放時(shí)為保證腳本正確執(zhí)行,最好將回放速度調(diào)整為slow,否則頁(yè)面若未加載完成,可能導(dǎo)致有些命令執(zhí)行失敗。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。