javascript - 量角器:计算虚拟列表中的所有元素
问题描述
我很难计算所有元素。它一次只显示 11 个元素。向下滚动时,第一个元素被下一个元素替换。
这就是我所拥有的:
element.all(by.css('.task-virtual-scroll')).click()
browser.actions().keyDown(protractor.Key.CONTROL).sendKeys(protractor.Key.END).perform();
function StringtoNumber(promiseOrValue) {
if (!protractor.promise.isPromise(promiseOrValue)) {
// If it isn't a promise, then convert a value
return parseInt(promiseOrValue, 10);
}
return promiseOrValue.then(function(stringNumber) {
// If it is a promise, then convert the result to a number
return parseInt(stringNumber, 10);
});
}
expect(element.all(by.css('mat-card>mat-card>mat-card-header')).count())
.toEqual((StringtoNumber(element(by.css('#mat-badge-content-1')).getText())));
// Expect that the notifications are equal to the notification in the badge
解决方案
试试下面的函数来获取计数
async function getCount(){
ele = element.all(by.css('mat-card>mat-card>mat-card-header'));
let counter:number =0;
for(i=0;i<200;i++){
await browser.sleep(2000) // Adjust the wait time based on the time taken by the page to load the next set of items
if(ele.get(i).isPresent()){
await browser.executeScript('arguments[0].scrollIntoView()', ele.get(i));
await browser.sleep(2000);
counter++;
}else{
await console.log('Counted all the items');
break;
}
}
使用上述函数获取商品数量
消除:browser.actions().keyDown(protractor.Key.CONTROL).sendKeys(protractor.Key.END).perform();
希望对你有帮助