所以对于一个特定的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只会选择第一个并检查一个。
有任何想法吗?
可能当您添加.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);});