XPATH是一門在XML文檔中查找信息的語言,XPATH可用來在XML文檔中對元素和屬性進行遍歷,主流的瀏覽器都支持XPATH,由於HTML頁面在DOM中表示爲XHTML文檔。
XPATH語言是基於XML文檔的樹結構,並提供了瀏覽樹的能力,經過多樣的標準來選擇節點。
Selenium WebDriver支持使用XPATH表達式來定位元素。
XPATH和CSS選擇器最重要的區別是XPATH能夠向前和向後查詢DOM結構的元素,而CSS選擇器只能向前查詢,這意味着XPATH能夠經過子元素來定位父元素!css
使用XPATH有以下幾種方法定位元素(相比CSS選擇器,方法稍微多一點):html
WebElement ele = driver.findElement(By.xpath("html/body/div/form/input"));
WebElement ele = driver.findElement(By.xpath("//input"));
WebElement ele = driver.findElement(By.xpath("//input[4]"));
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']"));
//查找全部input標籤中含有type屬性的元素 WebElement ele = driver.findElement(By.xpath("//input[@type]"));
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'
WebElement ele = driver.findElement(By.xpath("//input[@*='fuck']"));//匹配全部input元素中含有屬性的值爲fuck的元素
//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());