我有这个代码并且运行正常,但是我希望它在循环中运行,这样它将计算它在class="socal"
中有多少个元素,然后测试每个链接。
module.exports = {
'Unitel Fitness - click' : function (browser) {
browser
.url('http://m.unitel.ao/fit/')
.execute('scrollIntoView(alignToBottom)')
.waitForElementVisible('.socal>span:nth-child(1) a', 6000)
.moveToElement('.socal>span:nth-child(1) a', 3, 3)
.pause(6000)
.click(".socal>span:nth-child(1) a")
.pause(6000)
.keys(['\uE006'])
.window_handles(function (result) {
var handle = result.value[1];
browser.switchWindow(handle);
browser.pause(1000);
//browser.assert.urlContains('facebook');
browser.closeWindow();
})
.end();
}
};
我为此升级了代码,但仍然没有完全按照我的意愿行事。 结果如下:(我试过给了更多时间)
链接数:执行前4 i val:执行前1 i val:执行前2 i val:执行前3 i val:4?在等待元素< .socal> span:nth-child(“+ i +”)a>时超时存在8000毫秒。 - 期望“可见”但得到:未找到
module.exports = {
'Social links' : function (browser) {
browser
.url('http://m.unitel.ao/fit/')
.execute(function(){
return document.querySelectorAll(".socal>span").length;
},
function(links) {
total_links = links.value;
console.log("Number of links: " + total_links);
for (var i = 1; i <= total_links; i++) {
console.log("i val before execute: " + i);
browser.execute('scrollIntoView(alignToBottom)');
//browser.waitForElementVisible('.socal>span:nth-child("+ i +") a', 8000);
//call back function
browser.waitForElementVisible('.socal>span:nth-child("+ i +") a', 5000, function() {
browser.moveToElement('.socal>span:nth-child("+ i +") a', 3, 3);
browser.pause(8000);
browser.click(".socal>span:nth-child("+ i +") a");
browser.pause(6000);
browser.keys(['\uE006']);
browser.window_handles(function (result) {
var handle = result.value[1];
browser.switchWindow(handle);
browser.pause(8000);
//browser.assert.urlContains('facebook');
browser.closeWindow();
})
});
}
})
// .end();
}
};
答案 0 :(得分:0)
为什么循环何时可以获得一个集合并使用.length
?它的性能也更高。
client.getEls(classSel, function(collection) {
return collection.length;
});