WebdriverIO如何使用相同的选择器迭代元素

问题描述 投票:0回答:1

所以对于一个特定的div id,我告诉webdriverIO返回一个包含所有复选框的数组,如下所示:

browser.elements('div[data-test-id="filter: inventory source"] input[type="checkbox"]').value;

返回:

[ { ELEMENT: '0.39366615381480075-8',
    'element-6066-11e4-a52e-4f735466cecf': '0.39366615381480075-8',
    selector: 'div[data-test-id="filter: inventory source"] input[type="checkbox"]',
    value: { ELEMENT: '0.39366615381480075-8' },
    index: 0 },
  { ELEMENT: '0.39366615381480075-9',
    'element-6066-11e4-a52e-4f735466cecf': '0.39366615381480075-9',
    selector: 'div[data-test-id="filter: inventory source"] input[type="checkbox"]',
    value: { ELEMENT: '0.39366615381480075-9' },
    index: 1 },
  { ELEMENT: '0.39366615381480075-10',
    'element-6066-11e4-a52e-4f735466cecf': '0.39366615381480075-10',
    selector: 'div[data-test-id="filter: inventory source"] input[type="checkbox"]',
    value: { ELEMENT: '0.39366615381480075-10' },
    index: 2 }]

我遇到的问题是选择器都是一样的。当我使用forEach循环时,我无法迭代检查每个复选框。 WebdriverIO只会选择第一个并检查一个。

有任何想法吗?

selenium webdriver-io browser-automation
1个回答
1
投票

可能当您添加.value时,它会获得总元素大小的第一个元素值。 不熟悉WebdriverIO,但请尝试以下代码:

var valueAttrs = 
browser.elements('div[data-test-id="filter: inventory source"] input[type="checkbox"]')
    .map(function(e){ return e.getAttribute('value'); });

valueAttrs.forEach(v=>{console.log('value: ' + v);});
© www.soinside.com 2019 - 2024. All rights reserved.