2 回答
TA贡献1784条经验 获得超7个赞
我终于找到了解决这个问题的方法,DublinDev为我指出了正确的方向,他说expertScript不返回NodeLists。因此,我考虑在 executeScript 方法中处理 NodeList,并让它返回一个文本数组,而不是实际的 NodeList:
var arrRowsText = await browser.executeScript("return (function(){" +
"var nodes = document.querySelectorAll('" + css + "');" +
"var arrayRes = [];" +
"for (var j=0; j<nodes.length; j++){" +
" arrayRes.push(nodes[j].innerText);" +
"}" +
"return arrayRes;" +
"})();");
现在它就像一个魅力,元素文本使用innerText比使用getText()更快地读取。
TA贡献2080条经验 获得超4个赞
节点列表似乎通过该方法作为 webElements 数组返回,因此应该可以正常工作。当某些东西已经被编辑时,你也不需要使用。你能试试下面的代码吗?executeScriptgetText().then()await
async getTextFromHtmlTable(){
try{
var rows = element.all(by.css('table[id^="P"] tr'));
var numRows = await rows.count();
var arrRows = [];
for (var i = 2; i <= numRows; i++){
console.log("********Processing row: " + i);
var css = 'table[id^=\"P\"] tr:nth-child(' + i + ') td div div';
//**Slow solution: var arrRowsText = await element.all(by.css(css)).getText();
//Faster:
var arrRowsText = await browser.executeScript("return document.querySelectorAll('" + css + "')");
let allEleText = [];
for(let j = 0; j < arrRowsText.length; j++){
allEleText.push(await arrRowsText[j].getText());
}
arrRows.push(allEleText.join(';').replace(/;\s/gm, ";"));
}
return arrRows;
}catch(err){
console.log ('Some error: ' + err)
};
}
添加回答
举报