場景:需要重復增加地址欄信息,如果地址信息超過了5個就不開始增加
如圖:

1.找到控件集合,在遍歷每個子元素,在進行選擇
1.先找到最外層的div的控件集合

2.外層的css定位為:
int startSumAdress =driver.findElements(By.cssSelector("div#ship_addr_list > div.list")); 外層的地址集合列表 #集合
if(startSumAdress<5){
while (startSumAdress<5){
addAdress(); //新增地址
startSumAdress = op.getElements("ShippingAddressList").size();//每次都取最新的集合長度
Log.logInfo("現在是第幾個地址:"+startSumAdress);
}
}
3.取得集合中的某一個元素,如一個訂單列表,你需要取得他里面的一個訂單號在進行編輯
如圖,都測試環境的數據,應該沒有關系

1.取的他某一行的數據,肯定還是要先獲取控件集合
2.在取得他的某一行,我們以css為例
外層控件集合的css:
#userMain > div.userH_box.orderBox.p15 > table> tbody
第一行數據訂單的控件集合:
#userMain > div.userH_box.orderBox.p15 > table > tbody > tr:nth-child(2) > td:nth-child(1) > a
第二行數據訂單的控件集合:
#userMain > div.userH_box.orderBox.p15 > table > tbody > tr:nth-child(3) > td:nth-child(1) > a
從上發現:變化的是> tr:nth-child(2) 這里面的值
故事就開始了:
List<WebElement> rows =driver.findElements(By.cssSelector("#userMain > div.userH_box.orderBox.p15 > table > tbody > tr"))// 獲取列表行數,注意這個tr
for (int i = 1; i < rows.size(); i++) { //i就是控制你要取的那幾行
getcode = rows.get(i).findElement(By.cssSelector("td:nth-child(1)> a")).getText();//取得數據
if (getcode.equals(ordercode[0])) {
rows.get(i).findElement(By.cssSelector("td:nth-child(1)> a")).click();//點擊第一行的數組
Log.logInfo("快速支付訂單編號為:"+getcode);
Log.logInfo("查找到對應的訂單號!!!!");
break;
} else {
Log.logError("沒有查找到對應的訂單號!!!!");
}
Log.logInfo("getcode:" + getcode);
}
