Selenium_WebDriver_定位元素
版权声明:本文为博主原创文章,转载请注明出处。
定位单个元素
WebDriver提供了八种元素定位方法,Java中定位语句形如:driver.findElement(By.id());
何为元素定位?当我们使用百度进行信息搜索时,打开网址后,我们的眼睛会聚焦到搜索栏,然后在搜索栏中输入我们需要搜索的关键,然后点击“百度一下”按钮,从上面的描述中我们可以看到,要完成搜索我们必须找到“搜索栏 && 百度一下按钮”,我们有眼睛可以浏览页面去定位“搜索栏 && 百度一下按钮”的位置,那脚本怎么知道“搜索栏 && 百度一下按钮”在哪里呢,这就要用到元素定位方法,通过元素定位,相当于给浏览器驱动器安装了一双眼睛,这样就可以找到“搜索栏 && 百度一下按钮”的“位置”了;
|
元素定位方式 |
描述 |
示例及场景 |
|
id |
HTML规定id属性在HTML文档中必须是唯一的,这就类似于公民的身份证号,具有很强的唯一性。 |
示例:定位"百度一下"按钮,并点击; 语法: driver.findElement(By.id("su")).click(); 场景: <input type="submit" value="百度一下" id="su" class="btn self-btn bg s_btn"> |
|
name |
HTML规定name来指定元素的名称,因此它的作用更像是人的姓名。name的属性值,在当前页而中可以不唯一。 |
示例:定位"百度搜索首页”的输入框,并输入"Selenium"; 语法:driver.findElement(By.name("wd")).sendKeys("Selenium"); 场景:<input type="text" class="s_ipt" name="wd" id="kw" maxlength="100" autocomplete="off"> |
|
class name |
HTML规定class来指定元素的类名。 其用法与id、name类似。 |
示例:定位"百度一下"按钮,并点击; 语法:driver.findElement(By.className("btn self-btn bg s_btn")).click(); 场景: <input type="submit" value="百度一下" id="su" class="btn self-btn bg s_btn"> |
|
tag name |
HTML的本质就是通过tag来定义实现不同的功能,每一个元素本质上也是一个tag。因为一个tag往往用来定义一类功能,所以通过tag识别某个元素的概率很低。 |
语法1:driver.findElement(By.tagName("input")); 示例2:查找页面上有多少个input,就可以用input这个tagName来进行查找 语法2:List<WebElement> inputs = driver.findElements(By.tagName("input")); System.out.println(inputs.size()); |
|
link text |
专门用来定位文本链接 |
示例:定位"百度搜索主页"右上角的"新闻"文本链接,并点击; 语法:driver.findElement(By.linkText("新闻")).click(); 场景:<a href="http://news.baidu.com" target="_blank" class="mnav">新闻</a> |
|
partial link text [ˈpɑ:ʃl] |
parial link定位是对link定位的一种补充,有些文本链接会比较长,这个时候我们可以取文本链接的一部分定位,只要这一部分信息可以唯一地标识这个链接即可。 |
示例:定位"百度搜索主页"右上角的"更多产品"文本链接,并点击; 语法:driver.findElement(By.partialLinkText("更多产")).click(); 场景:<a href="http://www.baidu.com/more/" name="tj_briicon" class="s_bri" target="_blank"> 更多产品</a> |
|
xpath |
XPath是一种在XML文档中定位元素的语言。 这种方法几乎可以定位到页面上的任意元素。 还可直接使用find_element_by_xpath()方法来定位元素。 |
|
|
①绝对路径 |
XPath主要用标签名的层级关系来定位元素的绝对路径,最外层为html语言。有body文本内,一级一级往下查找,如果一个层级下有多个相同的标签名,那么就按上下顺序确定是第几个,例如div[2]表示当前层级下的第二个div标签。 |
|
|
②相对路径 (需要学习Xpath定位语法) |
示例:定位"百度一下"按钮,并点击; 语法:driver.findElement(By.xpath("//*[@id='su']")).click(); 场景:利用谷歌F12中自带的“Copy XPath”,获取到“百度一下”按钮的XPath路径; |
|
|
css selector |
CSS使用选择器来为页面元素绑定属性。 CSS可以较为灵活地选择控件的任意属性,一般情况下定位速度要比XPath快。 |
|
|
选择器(利用谷歌F12中自带的“Copy Selector”) |
||
|
#id id 选择器,选择id="***'的所有元素; |
示例:定位"百度一下"按钮,并点击; 语法:driver.findElement(By.cssSelector("#su")).click(); 场景:<input type="submit" value="百度一下" id="su" class="btn self-btn bg s_btn"> |
|
|
.class class 选择器,选择class="***"的所有元素; |
示例:定位"百度一下"按钮,并点击; 语法:driver.findElement(By.cssSelector(".btn self-btn bg s_btn")).click(); 场景:<input type="submit" value="百度一下" id="su" class="btn self-btn bg s_btn"> |
|
|
* |
选择所有元素 |
|
|
element |
选择所有<element>元素 |
|
|
element1 > element2 |
选择父元素为<element1 >的所有<element2>元素 |
|
|
element1 + element2 |
选择同一级中紧接在<element1>元素之后的所有<element2>元素 |
|
|
[attribute=value] |
选择target = value的所有元素 |
|
定位一组元素
定位一组元素的方法与定位单个元素的方法类似,唯一的区别是在单词 element 后面多了一个 s 表示复数。定位一组元素一般用于以下场景:
①批量操作元素,例如勾选页面上所有的复选框。
②先获取一组元素,再从这组对象中过滤出需要操作的元素。例如定位出页面上所有的 checkbox,然后选择其中的一个进行操作。
注:对获取到的获取到的元素进行操作时,操作页面不能有跳转,否则会出现页面失效错误“stale element reference: element is not attached to the page document”
|
findElements() |
原型 |
java.util.List<WebElement> findElements(By by) |
|
参数 |
和findElement的可取的参数是一样的; |
|
|
返回值 |
返回一个装有WebElement的List容器; 因此,可以使用Java中关于List相关的方法,如:size()获取webelement的个数; |
|
|
示例 |
示例说明:登录cnblog,并为"精华"页面的前2篇博文点击"推荐"; 关键语法: ①List<WebElement> elements = driver.findElements(By.className("diggit")); //定位所有的“推荐”按钮; ②element = elements.get(i);//获取单个博文的“推荐”按钮,用到了Java循环For语句,List的get()方法; ③element.click(); //点击“推荐”按钮; |
附上测试代码:
|
测试环境: ①Eclipse:jee-mars-4.5.2 ②Selenium:selenium-java-3.5.3 ③GoogleChrome:60 ④chromedriver:2.30; |
package com.SeleniumLib.jase; |
Selenium_WebDriver_定位元素的更多相关文章
- selenium定位元素(本内容从https://my.oschina.net/flashsword/blog/147334处转载)
注明:本内容从https://my.oschina.net/flashsword/blog/147334处转载. 在使用selenium webdriver进行元素定位时,通常使用findElemen ...
- Web自动化基础(一)使用Selenium定位元素
什么是元素?我们知道网页上有什么内容显示出来,比如一个按钮,一个输入框,一张图片,都可以理解成元素,这些元素是由html代码构成的,比如图片可以用<img>标签来展示,一个输入框可以用&l ...
- Appium学习路—Android定位元素与操作
一.常用识别元素的工具 uiautomator:Android SDK自带的一个工具,在tools目录下 monitor:Android SDK自带的一个工具,在tools目录下 Appium Ins ...
- webdriver中定位元素,报无法找到元素的问题
webdriver中定位元素,报无法找到元素的问题时,需要查看以下几点: 1 用火狐的firebug插件定位元素,确保这个元素的定位正确: 2 在火狐的firebug插件的,在html页签中输入fra ...
- WebDriver定位元素方法
如果把页面上的元素看作人的话,在现实世界如何找到某人呢?方法有三: 一.通过人本身的属性,例如他的姓名,手机号,身份证号,性别,这些可区别他人的属性.在web页面上的元素也有这些属性,例如,id.na ...
- Selenium2+python自动化8-SeleniumBuilder辅助定位元素
前言 福利来了,对于用火狐浏览器的小伙伴们,你还在为定位元素而烦恼嘛? 上古神器Selenium Builder来啦,哪里不会点哪里,妈妈再也不用担心我的定位元素问题啦!(但是也不是万能,基本上都能覆 ...
- appium关于定位元素
Windows上定位元素我用的是uiautomatorviewer 这个工具在你的SDK-tools目录下,点击uiautomatorviewer.bat启动,注意appium在跑的时候是取不到的 工 ...
- css读书笔记3:定位元素
定位元素要掌握css技术,核心就是要掌握元素定位. 一般把下面这条规则作为所有css样式表的第一条,初始化所有元素的内边距和外边距都为0: * {padding:0;margin:0;} 盒模型浏览器 ...
- 总结Selenium自动化测试方法(三)WebDriver定位元素方法
三.WebDriver定位元素 推荐使用的webdriver是firefox,因为他的firebug更能可以帮助定位页面元素使用 # create a new Firefox session cls. ...
随机推荐
- sizeof(extern类型数组)
error: #70: incomplete type is not allowed 用sizeof计算数组大小,编译器提示不允许使用不完整的类型.在keil上编译直接报错,拿到vs2010上编译可 ...
- mysql中OPTIMIZE TABLE的作用
转载▼ 1.先来看看多次删除插入操作后的表索引情况 mysql> SHOW INDEX FROM `tbl_name`; +----------+------------+----------- ...
- DEDECMS点击主栏目默认显示第一个子栏目列表的方法
本文实例讲述了DEDECMS点击主栏目默认显示第一个子栏目列表的方法.分享给大家供大家参考.具体分析如下: 今天公司有个需求是,点击导航上的父栏目进去默认显示第一个子栏目的列表,以下是具体实现方法,可 ...
- asp.net -mvc框架复习(6)-基于MVC实现简单计算器
1.创建好文件夹 2.视图层代码编写 <%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<dyn ...
- sqlite数据库的char,varchar,text,nchar,nvarchar,ntext的区别
1.CHAR.CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间,不足的自动用空格填充. 2.VAR ...
- ios开发 第一天
alloc 分配内存(类方法) init 调用构造函数 id可以替代任何数据类型(不加*号) 错误现象: 2013-06-27 21:44:21.769 FieldButtonFun[3465:113 ...
- Select、Poll、Epoll、 异步IO 介绍
一.概念相关介绍 同步IO和异步IO,阻塞IO和非阻塞IO分别是什么,到底有什么区别?不同的人在不同的上下文下给出的答案是不同的.所以先限定一下本文的上下文. 本文讨论的背景是Linux环境下的net ...
- mysql-冗余和重复索引
mysql允许在相同列上创建多个索引,无论是有意还是无意,mysql需要单独维护重复的索引,并且优化器在优化查询的时候也需要逐个地进行考虑,这会影响性能. 重复索引是指的在相同的列上按照相同的顺序创建 ...
- Hystrix-命令名称、分组以及线程池划分
命令名称: 1.1 以继承的方式实现Hystrix命令使用类名作为默认的命令名称,我们也可以在构造函数中通过Setter静态类来设置 1.2 为了保存每个命令分配的Setter分配,你也可以像这样缓存 ...
- spring boot 文件上传 文件过大 FileUploadBase$SizeLimitExceed
application.properties中加入 multipart.maxFileSizemultipart.maxRequestSize Spring Boot 1.3.x或者之前 multip ...