Selenium-xpath詳解

一、XPATH是什麼

XPATH是一門在XML文檔中查找信息的語言,XPATH可用來在XML文檔中對元素和屬性進行遍歷,主流的瀏覽器都支持XPATH,由於HTML頁面在DOM中表示爲XHTML文檔。
XPATH語言是基於XML文檔的樹結構,並提供了瀏覽樹的能力,經過多樣的標準來選擇節點。
Selenium WebDriver支持使用XPATH表達式來定位元素。
XPATH和CSS選擇器最重要的區別是XPATH能夠向前和向後查詢DOM結構的元素,而CSS選擇器只能向前查詢,這意味着XPATH能夠經過子元素來定位父元素!css

二、XPATH使用方法

使用XPATH有以下幾種方法定位元素(相比CSS選擇器,方法稍微多一點):html

a、經過絕對路徑定位元素(不推薦!)

WebElement ele = driver.findElement(By.xpath("html/body/div/form/input"));

b、經過相對路徑定位元素

WebElement ele = driver.findElement(By.xpath("//input"));

c、使用索引定位元素

WebElement ele = driver.findElement(By.xpath("//input[4]"));

d、使用XPATH及屬性值定位元素

WebElement ele = driver.findElement(By.xpath("//input[@id='fuck']"));
//其餘方法(看字面意思應該能理解吧)
WebElement ele = driver.findElement(By.xpath("//input[@type='submit'][@name='fuck']"));
WebElement ele = driver.findElement(By.xpath("//input[@type='submit' and @name='fuck']"));
WebElement ele = driver.findElement(By.xpath("//input[@type='submit' or @name='fuck']"));

e、使用XPATH及屬性名稱定位元素

//查找全部input標籤中含有type屬性的元素
WebElement ele = driver.findElement(By.xpath("//input[@type]"));

f、部分屬性值匹配(和CSS選擇器相似)

WebElement ele = driver.findElement(By.xpath("//input[start-with(@id,'fuck')]"));//匹配id以fuck開頭的元素,id='fuckyou'
WebElement ele = driver.findElement(By.xpath("//input[ends-with(@id,'fuck')]"));//匹配id以fuck結尾的元素,id='youfuck'
WebElement ele = driver.findElement(By.xpath("//input[contains(@id,'fuck')]"));//匹配id中含有fuck的元素,id='youfuckyou'

g、使用任意值來匹配屬性及元素

WebElement ele = driver.findElement(By.xpath("//input[@*='fuck']"));//匹配全部input元素中含有屬性的值爲fuck的元素

h、使用XPATH軸來定位元素

//XPATH軸沒有實際經驗,因此本文不討論它。

元素定位總結

//注:本專題只介紹java版
//By id
WebElement ele = driver.findElement(By.id());
//By Name
WebElement ele = driver.findElement(By.id());
//By className
WebElement ele = driver.findElement(By.className());
//By tabName
WebElement ele = driver.findElement(By.tagName());
//By linkText
WebElement ele = driver.findElement(By.linkText());
//By partialLinkText
WebElement ele = driver.findElement(By.partialLinkText());//經過部分文本定位鏈接
//By cssSelector
WebElement ele = driver.findElement(By.cssSelector());
//By XPATH
WebElement ele = driver.findElement(By.xpath());
相關文章
相關標籤/搜索