首页 > 解决方案 > 量角器:计算虚拟列表中的所有元素

问题描述

我很难计算所有元素。它一次只显示 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

标签: javascriptprotractore2e-testingangular-cdk-virtual-scroll

解决方案


试试下面的函数来获取计数

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();

希望对你有帮助


推荐阅读