我很难计算所有要素。一次仅显示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
答案 0 :(得分:0)
尝试以下功能获取计数
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();
希望它对您有帮助