Selenium webdriver是完全模拟用户在对浏览器进行操作,所有用户都是在页面进行的单击、双击、输入、滚动等操作,而webdriver也是一样,所以需要我们指定元素让webdriver进行单击、双击、输入等操作,所以元素定位是UI自动化测试的前提条件。可以联想到之前说的页面经常变动的项目为什么不适合进行UI自动化测试,如果元素一直在变动,你就要不停的修改代码,维护工作量太大,投入产出比就太低了。

Selenium提供了8种定位方式:

l Id

l Name

l Tag name

l Xpath

l Css

l Link text

l Partial Link text

l Class name

定位的基本语法为:

WebDriver driver =new FirefoxDriver();

driver.findElement(By.id("id"));

driver.findElement(By.name("name"));

driver.findElement(By.className("className"));

driver.findElement(By.linkText("链接全部文字"));

driver.findElement(By.partialLinkText("链接的部分文字"));

driver.findElement(By.xpath("xpath定位表达式"));

driver.findElement(By.cssSelector("CSS表达式"));

driver.findElement(By.tagName("标签名"));

Id定位相对准确些,因为在页面id一般是唯一的标识符,name可能定位到的元素不只有单个元素,可能不唯一,导致不能准确的定位元素,脚本出现报错。

举例说明(以百度首页为例):

WebDriver driver =new FirefoxDriver();

driver.navigate().to("https://www.baidu.com/"); //输入URL,进入百度主页

driver.manage().window().maximize();  //窗口最大化

driver.findElement(By.id("kw")).sendKeys("selenium");  //使用id定位,在百度输入框中输入selenium关键词

driver.findElement(By.xpath("//input[@id='su']")).click();  //使用xpath定位,单击提交按钮

主要说下xpath定位:

1.使用绝对路径定位:

例如:html/body/div/div/div/div/div/form/input[@id=’kw’];

2.使用相对路径定位:

例如://input[@id=’kw’];

其中”//“表示在所有层级中进行查找,建议使用相对路径进行定位,因为相对路径相对的简洁些,不管页面发生一下什么变化,只要id值为kw的input元素还在就可以定位到,这样可以降低代码维护成本。

3.使用索引号进行定位:

//input[2]   表示xpath在定位查找元素时,选择第二个tagname为input的元素即为所需元素,遇到页面HTML层级比较复杂的页面不建议使用索引号定位。

4.使用页面元素的属性值来定位:

//img[@alt=’div1-img1’];       此xpath定位的是alt属性值为div1-img1的图片元素,北侧网页的元素通常会包含各种各样的属性值,并且很多的属性值是唯一的,强烈建议使用相对路径结合属性值的定方式来定位,这种准确率相对较高。

预期定位的页面元素

定位表达式

使用的属性值

定位页面的一张图片

//img[@href=’http://www.sogou.com’]

使用img的href属性

定位第2个div中的第一个输入框

//div[2]/input[@name=’kw’]

使用input的name属性

定位第1个div中的第一个链接

//div[@name=’div2’]/a[@href=’http://www.sogou.com’]

使用a的href属性

定位页面的查询按钮

//input[@type=’button’]

使用input的type属性

5.使用页面元素的文本定位:

//a[text()=’百度搜索’]   定位文本为”百度搜索“的链接

//a[contains(text(),’百度’)]   定位文本包含”百度“字样的链接

6.CSS定位

7.JQuery定位

页面元素的定位是在整个自动化测试中都需要用到的技能,也是最繁琐的,因为你要去不断的试错,不断的运行脚本去检查自己的元素定位是否有效,这个占了整个测试很大一部分时间。

selenium元素定位篇的更多相关文章

  1. 自动化测试基础篇--Selenium元素定位

    摘自https://www.cnblogs.com/sanzangTst/p/7457111.html 一.Selenium元素定位的重要性: Web自动化测试的操作:获取UI页面的元素,对元素进行操 ...

  2. selenium元素定位之css选择器

    在selenium元素定位时会用到css选择器选取元素,虽说xpath在定位元素时能解决大部分问题,但使用css选择器选取元素也是一种不错的选择. css相较与xpath选择元素优点如下: 表达式更加 ...

  3. Selenium3 + Python3自动化测试系列二——selenium元素定位

    一.selenium元素定位 Selenium对网页的控制是基于各种前端元素的,在使用过程中,对于元素的定位是基础,只有准去抓取到对应元素 才能进行后续的自动化控制,我在这里将对selenium8种元 ...

  4. selenium元素定位陷阱规避

    为什么selenium可以在各个浏览器上运行?因为selenium在与各个浏览器驱动执行前,会先把脚本转化成webdriver, webdriver wire协议(一种json格式的协议),这样就与脚 ...

  5. python学习之——selenium元素定位

    web自动化测试按步骤拆分,可以分为四步操作:定位元素,操作元素,获取返回结果,断言(返回结果与期望结果是否一致),最后自动出测试报告. 其中定位元素尤为关键,此篇是使用webdriver通过页面各个 ...

  6. python selenium 元素定位(三)

    上两篇的博文中介绍了python selenium的环境搭建和编写的第一个自动化测试脚本,从第二篇的例子中看出来再做UI级别的自动化测试的时候,有一个至关重要的因素,那就是元素的定位,只有从页面上找到 ...

  7. 我是这么学习Selenium元素定位操作的

    写在前面 做web自动化测试都有体会,本质也就是通过操作页面元素对象来模拟用户操作行为,那么首先我们先找到这些元素对象,然后才能进行一系列操作. 我们得先告诉自动化工具或者说代码要操作那个元素,毕竟代 ...

  8. Selenium+Java(三)Selenium元素定位

    前言 使用Selenium做元素定位的时候,需要用到HTML的知识,所以最好是能懂得HTML的基本知识. 一.页面元素的查看(以百度为例) 打开IE浏览器,点击F12进入开发者模式,点击图中红圈圈中的 ...

  9. Java + selenium 元素定位(5)之By Xpath

    这篇关于Xpath方法的文章和之前那篇CSS的方法一样,使用前,需要先掌握一些Xpath的相关知识.当然,网上也有各种工具可以帮助我们获取到元素的Xpath,但是这并不代表着我们就可以不用了解Xpat ...

随机推荐

  1. HttpClient的替代者 - RestTemplate

    需要的包 ,除了Spring的基础包外还用到json的包,这里的数据传输使用json格式 客户端和服务端都用到一下的包 <!-- Spring --> <dependency> ...

  2. dll文件32位64位检测工具以及Windows文件夹SysWow64的坑

    自从操作系统升级到64位以后,就要不断的需要面对32位.64位的问题.相信有很多人并不是很清楚32位程序与64位程序的区别,以及Program Files (x86),Program Files的区别 ...

  3. Node-Webkit打包

    1.node-webkit是什么? NW.js is an app runtime based on Chromium and node.js. You can write native apps i ...

  4. ASP.NET MVC5+EF6+EasyUI 后台管理系统(73)-微信公众平台开发-消息管理

    系列目录 前言 回顾上一节,我们熟悉的了解了消息的请求和响应,这一节我们来建立数据库的表,表的设计蛮复杂 你也可以按自己所分析的情形结构来建表 必须非常熟悉表的结果才能运用这张表,这表表的情形涵盖比较 ...

  5. 从零开始编写自己的C#框架(25)——网站部署

    导航 1.关掉访问保护 2.发布网站 3.复制网站到服务器 4.添加新网站 5.设置网站访问权限 6.设置文件夹访问权限 7.控制可更新文件夹执行权限 8.设置“应用程序池”.net版本与模式 9.附 ...

  6. 谈谈一些有趣的CSS题目(八)-- 纯CSS的导航栏Tab切换方案

    开本系列,谈谈一些有趣的 CSS 题目,题目类型天马行空,想到什么说什么,不仅为了拓宽一下解决问题的思路,更涉及一些容易忽视的 CSS 细节. 解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题 ...

  7. WebGIS中等值面展示的相关方案简析

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 等值面是气象.环保等相关项目上常用到的效果展示.在传统的CS项 ...

  8. UVa 122 Trees on the level

    题目的意思: 输入很多个节点,包括路径和数值,但是不一定这些全部可以构成一棵树,问题就是判断所给的能否构成一棵树,且没有多余. 网上其他大神已经给出了题目意思:比如我一直很喜欢的小白菜又菜的博客 说一 ...

  9. C#语法糖大汇总

    首先需要声明的是"语法糖"这个词绝非贬义词,它可以给我带来方便,是一种便捷的写法,编译器会帮我们做转换:而且可以提高开发编码的效率,在性能上也不会带来损失.这让java开发人员羡慕 ...

  10. Android之文件数据存储

    一.文件保存数据介绍 Activity提供了openFileOutput()方法可以用于把数据输出到文件中,具体的实现过程与在J2SE环境中保存数据到文件中是一样的.文件可用来存放大量数据,如文本.图 ...