selenium中Xpath和CSS Selector的使用方法
一、selenium中Xpath的使用方法
1. 什么是xpath?
Xpath是XML的路径语言,通俗一点讲就是通过元素的路径来查找这个标签元素
2. 练习Xpath的工具
火狐浏览器,下载插件FireBug和FirePath
3. Xpath使用方法
注:默认死格式,先写//*代表定位页面下的所有元素
(1)Xpath支持ID、class和name定位功能
通过id定位: //*[@id='i1']
通过class定位://*[@class='classname']
通过name定位: //*[@name='name']
(2)如果便签没有id,class和name三个综述性,Xpath还支持属性定位功能
@代表以属性定位,后面看而已接标签中的任意属性,比如:
//*[@placeholder='请通过XPATH定位元素']
(3)当标签的属性重复时,Xpath提供了通过标签来进行过滤,//input显示所有的input标签
//input[@placeholder='请通过XPATH定位元素']
(4)当标签页重复时,Xpath提供了层级过滤
例如:找不到儿子,那么久先找他的父级,实在不行可以找他的祖父级
//div/div[@id='dis']
(5)当层级都重复时,可以通过单个层级的属性进行定位
//div/div[@id='w']/div
(6)一个元素它的兄弟元素跟它的标签一样,这时候无法通过层级定位,因为都是一个父亲生的,多胞胎儿子,Xpath提供了索引过滤,索引从1开始,而非0
//select[2]
(7)上面几种如果都用上了惠州还重复,我们就可以使用Xpath提供的终极神器,逻辑运算定位。and或or
//select[@name='city' and @size='4']
//select[@name='city' or @size='4']
二、selenium中CSS Selector的使用方法
1. 什么是CSS Selector?
CSS Selector定位实际就是HTML的CSS选择器的标签定位
2. 工具
火狐浏览器,下载插件FireBug和FirePath
3. CSS Selector的使用方法
(1)Css selector支持id、class的定位,与html中的css定位相同
通过id定位 #i1
通过class定位 .classname
通过class定位多个class .classname.c2.c3
(2)通过属性定位,Css Selector支持任意属性定位
[name='name']
(3)单单属性定位不足以满足我们的定位需求,Css Selector提供了标签属性组合定位
input[name='name'] input标签下name属性等于‘name’的
input#i1 input标签下id是i1的
input.classname input标签下class是classname的
div.inner>input div标签下class是inner的 带有input标签的(注意尖角号)
Div.inner下有多个,但是不能用索引定位,要结合尖角号+属性使用
(4)Css selector多属性组合过滤,没有and,只需要多个[]连接就可以
select[name='city'][size='4'][multiple='multiple']
(5)Css selector模糊匹配
^= 匹配元素属性以什么开头 input[value^="登"]
$= 匹配属性以什么结尾 input[value$="录"]
*= 匹配属性包含什么值 input[value*="录"]
selenium中Xpath和CSS Selector的使用方法的更多相关文章
- Xpath 和Css Selector使用
Xpath是xml的路径语言,就是通过元素的路径来查找标签元素. Xpath直接在火狐浏览器的firebug中练习,49版本一下的火狐才能用firebug插件. Xpath的使用方法 注://* ...
- selenium中Xpath标签定位和cssSelectors定位(优先用cssSelectors)
二者的区别:xpath 支持角标定位,cssselector不支持 1.XPath是XML的路径语言,通俗一点讲就是通过元素的路径来查找到这个标签元素. xpath支持属性定位,无论是默认属性还是自定 ...
- selenium中Xpath轴定位方法
1.Xpath轴:轴可定义相对于当前节点的节点集. 使用语法:轴名称::节点名称 例://input[@data-value="SXRYNAME"]/parent::td/foll ...
- selenium:css_selector定位详解(css selector和xpath的比较)
selenium使用css selector和xpath的比较 selenium提供的定位方式(常用) ID NAME CLASS CSS SELECTOR XPATH 推荐的定位方式的优先级 优 ...
- Web自动化测试:xpath & CSS Selector定位
Xpath 和 CSS Selector简介 CSS Selector CSS Selector和Xpath都可以用来表示XML文档中的位置.CSS (Cascading Style Sheets)是 ...
- Selenium之Css Selector使用方法
什么是Css Selector? Css Selector定位实际就是HTML的Css选择器的标签定位 工具 Css Selector的练习建议使用火狐浏览器,下载插件,FireFinder.Fire ...
- 『心善渊』Selenium3.0基础 — 6、Selenium中使用XPath定位元素
目录 1.Selenium中使用XPath查找元素 (1)XPath通过id,name,class属性定位 (2)XPath通过标签中的其他属性定位 (3)XPath层级定位 (4)XPath索引定位 ...
- 【WEB自动化】【第一节】【Xpath和CSS元素定位】
目前自动化测试开始投入WEB测试,使用RF及其selenium库,模拟对WEB页面进行操作,此过程中首先面对的问题就是对WEB页面元素的定位,几乎所有的关键字都需要传入特定的WEB页面元素,因此掌握常 ...
- Selenium自动化中DOM,XPATH,CSS定位Web页面对象的优劣性分析
加速IE浏览器自动化执行效率:Selenium自动化中DOM,XPATH,CSS定位Web页面对象的优劣性分析 1.技术背景 在Web应用中,用户通过键盘在输入框中输入值和鼠标点击按钮,链 ...
随机推荐
- XML语法笔记
XML(可扩展标记语言) XML的特点: XML是一种标记语言,适合跨平台.跨语种信息交互XML被用于存储.传输数据XML可扩展性良好,没有预定义标签,需要用户自定义标签XML具有自我描述性XML采用 ...
- Appium&python
Appium官网所描述的特性,都很吸引人,刚好最近在研究Mobile Automation Testing,所以很有兴趣探索下Appium这个年轻的工具. 不过看了官网的documents,实在是让初 ...
- TC SRM 583 DIV 2
做了俩,rating涨了80.第二个题是关于身份证的模拟题,写的时间比较长,但是我认真检查了... 第三个题是最短路,今天写了写,写的很繁琐,写的很多错. #include <cstring&g ...
- 关于在PHP中当一个请求未完成时,再发起另一个请求被阻塞的问题
最近做项目的时候遇到个问题,就是做阿里云oss大文件上传进度条显示,因为要实时查询上传分片进度,所以在上传的同时必须要再发起查询的请求,但是一直都是所有分片上传完成后查询的请求才执行,刚开始以为是阿里 ...
- Java面试必会知识点
1.== 和 equals()比较: (1)== 是运算符,equals()是Object中定义的方法: (2)== 比较的是 数值 是否相同,基本类型比较数值,引用类型比较对象地址的数值:且变量类型 ...
- vue中显示和隐藏导航
const router = new VueRouter({ mode: 'history', routes: [ { path: '/first', component: firstView, me ...
- JavaScript Map对象的实现
1. [代码]js代码 /* * MAP对象,实现MAP功能 * * 接口: * size() 获取MAP元素个数 * isEmpty() 判断MAP是否为空 * clear() ...
- 2013级新生程序设计基础竞赛-正式赛 F 异或最大值 解题报告
F - 异或最大值 Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) Subm ...
- 一步一步学Silverlight 2系列(8):使用样式封装控件观感
述 Silverlight 2 Beta 1版本发布了,无论从Runtime还是Tools都给我们带来了很多的惊喜,如支持框架语言Visual Basic, Visual C#, IronRuby, ...
- skynet源码阅读<4>--定时器实现
昨天和三石公聊天,他提到timer的实现原理,我当时迟疑了一下,心想timer不是系统底层时钟中断驱动上层进程/线程,累积计时实现的么?他简述了timer的实现,什么堆排序,优先级队列等,与我想象的不 ...