Selenium webdriver 学习总结-元素定位

Selenium webdriver 学习总结-元素定位

webdriver提供了丰富的API,有多种定位策略:id,name,css选择器,xpath等,其中css选择器定位元素效率相比xpath要高些,使用id,name属性定位元素是最可靠,效率最高的一种办法。

  1、工具选择:在我们开发测试脚本的过程中各个浏览器给我们也提供了方便定位元素的工具,我比较喜欢使用firefox的firebug工具,也是目前很多开发测试人员比较热衷的选择,原因是firefox是唯一能够集成selenium IDE的浏览器,并且firebug给用户提供了丰富的扩展组件,我们可以根据自己的需要来选择,一般情况下,使用firebug+firefinder就足够使用了,firefinder支持xpath以及css选择器定位元素的功能,很方便帮助我们调试测试脚本

  2、元素定位的方法:findElement() 与 findElements()

  findElement() 该方法返回基于指定查询条件的webElement对象,或抛出不符合条件的异常  eg:driver.findElement(By.id("userID"));

  findElements() 该方法返回指定查询条件的WebElement的对象集合,或返回null

  3、WebElement对象提供的各种定位元素策略


ID:driver.findElement(By.id(<elementID>))

Name:driver.findElement(By.name(<elementName>))

className:driver.findElement(By.className(<elementClassName>))

tagName:driver.findElement(By.tagName(<htmlTagName>))

linkText:driver.findElement(By.linkText(<linkText>))

partialLinkText:driver.findElement(By.partialLinkText(<partialLinkText>))

css:driver.findElement(By.cssSelector(<cssSelector>))

xpath:driver.findElement(By.xpath(<xpathQuery>))

  4、webelement类提供了诸多方法,在我们开发脚本过程中如何选择最可靠,效率最高的方法,使用id,name是首选,因为他们在html标签中是唯一的,所以是最可靠的

  ID定位:driver.findElement(By.id("username"))

  name定位:driver.findElement(By.name("username"))

  class定位:driver.findElement(By.className("username"))

  多学一招:WebElement类支持查询子类元素,如果页面中存在重复元素,但在不同div中,我们可以先定位到其父元素,然后定位其子元素,方法如下:

  WebElement hello = driver.findElement(By.id("div1")).findElement(By.lindText("hello"));

  5、使用WebElements定位多个相似的元素,比如页面中存在五个单选按钮,他们有相同的class属性,值为:myRadio,我们想对五个按钮循环操作,我们可以把它们全部取出来放到集合中,然后做循环操作,如下:


List<WebElement> radios = driver.findElements(By.className("myRadio"));

for(int i = 0;i<radios.size();i++){

radios.get(i).click();

}

  其他定位方法与操作id,name类似,这里不再赘述,接下来我着重对css选择器与Xpath描述下

  一、WebDriver 的By类中提供了cssSelector()方法,该方法使用有以下几种形式:

  1、使用相对路径定位元素

  如,我们要定为DOM中的input元素,我们可以这样操作,不考虑其在DOM中的位置,但这样做存在一定弊端,当DOM中存在多个input元素时,该方法总返回DOM中的第一个元素,这并不是我们所期待的

  eg:WebElement username = driver.findElement(By.cssSelector("input"));

  另外,为了使用这种方法更准确的定位元素,我们可以结合该元素的其他属性来实现精确定位的目的

  a、结合id来定位,driver.findElement(By.cssSelector("input#username")); 在标签与id之间使用#连接,如果对css了解的朋友一看就知道为什么会这样写了,不了解也没关系,只要记住这种写法就OK了

  另外该方法也可简写为driver.findElement(By.cssSelector("#username")); 有点儿类似于id选择器

b、使用元素的任何属性来定位元素

  driver.findElement(By.cssSelector("标签名[属性名=‘属性值‘]"));

  c、匹配部分属性值


^=        driver.findElement(By.cssSelector("标签名[属性名^=‘xxx‘]"));  匹配属性值以xxx开头的元素

$=        driver.findElement(By.cssSelector("标签名[属性名$=‘xxx‘]"));  匹配属性值以xxx结尾的元素

*=         driver.findElement(By.cssSelector("标签名[属性名^=‘xxx‘]"));  匹配属性值包含xxx的元素

  2、使用相对+绝对路径方法,这里是我自己定义的方法,方便记忆,的确也是这样来实现的

  driver.findElement(By.cssSelector("div#login>input"))   该方法中“div#login>input” 首先通过相对路径定位到id为login的div元素,然后查找其子元素input(绝对路径)

  二、使用xpath定位元素,相比cssSelector,xpath是我比较常用的一种定位元素的方式,因为它很方便,缺点是,消耗系统性能

  1、使用绝对路径定位元素

  driver.findElement(By.xpath("/html/body/div/form/input"))

  2、使用相对路径定位元素

  driver.findElement(By.xpath("//input"))   返回查找到的第一个符合条件的元素

  3、使用索引定位元素,索引的初始值为1,注意与数组等区分开

  driver.findElement(By.xpath("//input[2]"))   返回查找到的第二个符合条件的元素

  4、结合属性值来定位元素

  driver.findElement(By.xpath("//input[@id=‘username‘]"));

  driver.findElement(By.xpath("//img[@alt=‘flowr‘]"));

  5、使用逻辑运算符,结合属性值定位元素,and与or

  driver.findElement(By.xpath("//input[@id=‘username‘ and @name=‘userID‘]"));

  6、使用属性名来定位元素

  driver.findElement(By.xpath("//input[@button]"))

  7、类似于cssSlector,使用部分属性值匹配元素


starts-with()    driver.findElement(By.xpath("//input[stars-with(@id,‘user‘)]"))

ends-with        driver.findElement(By.xpath("//input[ends-with(@id,‘name‘)]"))

contains()        driver.findElement(By.xpath("//input[contains(@id,"ernam")]"))

  8、使用任意属性值匹配元素

  driver.findElement(By.xpath("//input[@*=‘username‘]"))

  9、使用xpath轴来定位元素

  这里略了,详见w3school.com

  三、使用innerText定位元素

  1、使用cssSelector查找innerText定位元素

  driver.findElement(By.cssSelector("span[textContent=‘新闻‘]"));

  2、使用xpath的text函数

  driver.findElement(By.xpath("//span[contains(text(),‘hello‘)]"))   包含匹配

  driver.findElement(By.xpath("//span[text()=‘新闻‘]"))     绝对匹配

转自:http://www.blogjava.net/qileilove/archive/2013/12/25/408002.html

时间: 2024-10-10 10:03:25

Selenium webdriver 学习总结-元素定位的相关文章

java selenium webdriver实战 页面元素定位

自动化测试实施过程中,测试程序中常用的页面操作有三个步骤 1.定位网页上的页面元素,并存储到一个变量中 2.对变量中存储的页面元素进行操作,单击,下拉或者输入文字等 3.设定页面元素的操作值,比如,选择下拉列表中的那个下拉列表或者输入框中输入什么值 其中定位页面元素是三步骤的第一步,本篇介绍常用的定位方法 webDriver对象的findElement函数用于定位一个页面元素,findElements函数用户定位多个页面元素,定位的页面元素使用webElement对象进行存储 常用的方法有: 1

【selenium学习笔记】webdriver进行页面元素定位

[selenium学习笔记]webdriver进行页面元素定位 进行Web页面自动化测试,对页面上的元素进行定位和操作是核心.而操作又是以定位为前提的,因此,对页面元素的定位是进行自动化测试的基础. 页面上的元素就像人一样,有各种属性,比如元素名字,元素id,元素属性(class属性,name属性)等等.webdriver就是利用元素的这些属性来进行定位的. 可以用于定位的常用的元素属性: id name class name tag name link text partial link te

selenium webdriver学习--通过id、name定位,输入内容,搜索,关闭操作

selenium webdriver学习--通过id.name定位,输入内容,搜索,关闭操作: 打开谷歌浏览器,输入不同的网站,搜索框的定位含有不同元素(有时为id,有时为name) import org.openqa.selenium.By;import org.openqa.selenium.WebDriver;import org.openqa.selenium.WebElement;import org.openqa.selenium.chrome.ChromeDriver; impor

selenium webdriver学习(十)------------如何把一个元素拖放到另一个元素里面(转)

selenium webdriver学习(十)------------如何把一个元素拖放到另一个元素里面 博客分类: Selenium-webdriver 元素拖放drag and drop Q群里有时候会有人问,selenium  webdriver怎么实现把一个元素拖放到另一个元素里面.这一节总一下元素的拖放. 下面这个页面是一个演示拖放元素的页面,你可以把左右页面中的条目拖放到右边的div框中. http://koyoz.com/demo/html/drag-drop/drag-drop.

Python3.x:Selenium中的webdriver进行页面元素定位

Python3.x:Selenium中的webdriver进行页面元素定位 页面上的元素就像人一样,有各种属性,比如元素名字,元素id,元素属性(class属性,name属性)等等.webdriver就是利用元素的这些属性来进行定位的. 可以用于定位的常用的元素属性: id name class name tag name link text partial link text xpath css selector 对应于webdriver中的定位一个元素方法分别是: driver.find_e

selenium webdriver学习(五)------------iframe的处理(转)

selenium webdriver学习(五)------------iframe的处理 博客分类: Selenium-webdriver 如何定位frame中元素 有时候我们在定位一个页面元素的时候发现一直定位不了,反复检查自己写的定位器没有任何问题,代码也没有任何问题.这时你就要看一下这个页面元素是否在一个iframe中,这可能就是找不到的原因之一.如果你在一个default content中查找一个在iframe中的元素,那肯定是找不到的.反之你在一个iframe中查找另一个iframe元

(java)selenium webdriver学习---三种等待时间方法:显式等待,隐式等待,强制等待

selenium webdriver学习---三种等待时间方法:显式等待,隐式等待,强制等待 本例包括窗口最大化,刷新,切换到指定窗口,后退,前进,获取当前窗口url等操作: import java.util.Set;import java.util.concurrent.TimeUnit; import org.jsoup.Jsoup;import org.jsoup.nodes.Document;import org.openqa.selenium.By;import org.openqa.

(java)selenium webdriver学习---实现简单的翻页,将页面内容的标题和标题链接取出

selenium webdriver学习---实现简单的翻页,将页面内容的标题和标题链接取出: 该情况适合能能循环page=1~n,并且每个网页随着循环可以打开的情况, 注意一定是自己拼接的url可以打开,如:http://ask.testfan.cn/articles?page=15,就可以翻到文章分类的第15页: import java.io.File; import java.io.IOException; import java.util.ArrayList; import java.u

selenium webdriver学习(八)------------如何操作select下拉框(转)

selenium webdriver学习(八)------------如何操作select下拉框 博客分类: Selenium-webdriver 下面我们来看一下selenium webdriver是如何来处理select下拉框的,以http://passport.51.com/reg2.5p这个页面为例.这个页面中有4个下拉框,下面演示4种选中下拉框选项的方法.select处理比较简单,直接看代码吧:) Java代码   import org.openqa.selenium.By; impo