自动化测试selenium----css选择器总结
选择器 | 示例 | 描述 |
* | * | 匹配任何元素 |
element | DIV | 标签选择器,匹配所有使用DIV标签的元素 |
.class | .tips | class选择器,匹配所有class属性中包含info的元素 .a.b则匹配同时包含a和b的元素 |
#id | #username | id选择器,匹配id属性为username的元素 |
element,element | DIV,SPAN | 多元素选择器,选择所有DIV和SPAN全集,使用,分隔 |
element element | DIV SPAN | 后代元选择器,匹配所有的DIV的SPAN后代元素,中间使用空格分隔 |
elemen> telement | DIV>SPAN | 子元素选择器,匹配所有的DIV的SPAN子元素,中间使用> 分隔 |
elemen+ telement | DIV+SPAN | 毗邻元素选择器,匹配紧随DIV后面的同级SPAN元素(only one),不一定就是一个同一个div后面的一个 |
elemen~ telement | DIV~SPAN | 同级元素选择器,匹配所有DIV后面的同级SPAN元素,可以隔着其他元素 |
[attribute] | [att] | 所有包含att属性的元素 |
[attribute=vlaue] |
DIV [att='val']
|
匹配所有att属性为val的DIV元素 |
[attribute^=vlaue]
[attribute|=vlaue]
|
DIV[att^='val'] | 匹配所有att属性以val开头的DIV元素 w3s使用的是| |
[attribute$=vlaue] | DIV[att$='val'] | 匹配所有att属性以val结尾的DIV元素 |
[attribute*=vlaue]
[attribute~=vlaue]
|
DIV[att*='val'] | 匹配所有att属性包含val的DIV元素 |
[attr1=vla1][attr2*=vla2] |
DIV [att1='v1'][att2*='v2']
|
匹配所有att属性为v1,att2属性包含v2的DIV元素
|
[attr1=vla1],[attr2*=vla2] | DIV [att1='v1'],[att2*='v2'] | 同上 或关系 |
:link | a:link | 选择所有未被访问的链接 |
:visited | a:visited | 选择所有已被访问的链接 |
:active | a:active | 选择所有活动链接 |
:hover | a:hover | 选择鼠标指针所在的链接 |
:focus | input:focus | 选择获取焦点的input元素 |
:first-child
|
p:first-child
|
选择所有符合如下规则的p元素,p必须是其父元素的第一个子元素 |
:last-child
|
p:last-child
|
选择所有符合如下规则的p元素,p必须是其父元素的最后一个子元素 |
:first-of-type
|
p:first-of-type
|
选择父元素的首个p子元素的集合,和first-child区别是前面可以有非p元素,不一定是父元素的第一个子元素 |
:last-of-type
|
p:last-of-type
|
选择父元素的首最后一个p子元素的集合,和last-child区别是后面可以有非p元素,不一定是父元素的最后一个子元素 |
:only-of-type
|
p:only-of-type
|
选择父元素的只有唯一个p子元素的集合 |
:nth-child(n)
|
p:nth-child(2)
|
选择属于其父元素的第二个子元素的每个 <p> 元素
|
:nth-last-child(n)
|
p:nth-last-child(2)
|
同上,从最后一个元素来计数 |
:nth-of-type(n)
|
p:nth-of-type(2)
|
选择父元素的第二个p子元素的集合,和:nth-child(n) 区别是前后可以有非p元素,不一定是父元素的第二个子元素 |
:nth-last-of-type(n)
|
p:nth-last-of-type(2)
|
同上,从最后一个元素来计数 |
:root
|
:root
|
选择文档的根元素 |
:empty
|
p:empty
|
选择没有子节点的p元素包含文本节点 |
:enabled
|
input:enabled
|
选择每个启用的input元素 |
:disabled
|
input:disabled
|
选择每个禁用的input元素 |
:checked
|
input:checked
|
选择每个被选中的input元素 |
:not(selector)
|
:not(p)
|
选择所有非p元素
|
Selenium 中则是采用 | 了来自Sizzle 的css3 | 定位扩展,它的语法更加灵活易懂。 |
:nth(n)
:eq(n)
|
li:nth(2)
li:eq(2)
|
同:nth-child(n),但是从0开始 |
:first | li:first | 同:first-child |
:last | li:last | 同:last-child |
:even | li:even | 在其父元素中的li 子元素集合中排在偶数位的集合 |
:odd | li:odd | 在其父元素中的li 子元素集合中排在奇数位的集合 |
:lt(n) | li:lt(2) | 在其父元素中的li 子元素集合中排在第n位之前的所有元素集合(不包含n),n从0开始 |
:gt(n) | lg:lt(2) | 在其父元素中的li 子元素集合中排在第n位之后的所有元素集合(不包含n),n从0开始 |
:only-child | div:only-child | 同:only-of-type |
:empty | p:empty | 同CSS原生选择器:empty |
:input | :input | 获取所有input类型的元素(包含input、select、textarea) |
:text, :checkbox, :file, :password, :submit, :image, :reset, :button | ... | 获取指定类型的元素 |
自动化测试selenium----css选择器总结的更多相关文章
- selenium中CSS选择器定位
selenium元素定位,CSS选择器定位效率会高很多. CSS选择器用于选择你想要的元素的样式的模式.表格摘自“菜鸟教程”,具体用法可去查阅 选择器 示例 示例说明 CSS .class .intr ...
- Selenium(五):CSS选择器(二)
1. CSS选择器 1.1 选择语法联合使用 CSS selector的另一个强大之处在于:选择语法可以联合使用. html代码: <div id='bottom'> <div cl ...
- Selenium(四):CSS选择器(一)
1. CSS选择器 前面我们学习了根据 id.class属性.tag名选择元素. 如果我们要选择的元素没有id.class 属性,或者有些我们不想选择的元素也有相同的id.class属性值,怎么办呢? ...
- selenium元素定位之css选择器
在selenium元素定位时会用到css选择器选取元素,虽说xpath在定位元素时能解决大部分问题,但使用css选择器选取元素也是一种不错的选择. css相较与xpath选择元素优点如下: 表达式更加 ...
- Selenium系列(十二) - 自动化必备知识之CSS选择器的详细使用
如果你还想从头学起Selenium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1680176.html 其次,如果你不懂前端基础知识, ...
- selenium - css 定位
前言: CSS(Cascading Style Sheets)是一种语言,它被用来描述 HTML 和 XML 文档的表现. CSS 使用选择器来为页面元素绑定属性.这些选择器可以被 selenium ...
- 自动化测试selenium教程
什么是自动化测试: 自动帮我们测试一个系统里面的主要功能,一个app.电脑网站.网页,每个系里面许多的功能,好比一个淘宝页面,里面N多功能,登录.注册,推荐,商品详情.评论等等:软件生命周期:需求调研 ...
- 使用CSS选择器进行元素定位
在selenium webdriver中,支持使用CSS选择器来进行元素定位,事实在真的投入工作,大量编辑用例和元素定位的时候,使用css 和 xpath才是经常需要用到的. 之前有专门讲过使用xpa ...
- CSS选择器定位的使用
CSS 可以比较灵活选择控件的任意属性,一般情况下定位速度要比XPath 快,但对于初学者来说比较难以学习使用,下面我们就详细的介绍CSS 的语法与使用.一.CSS 选择器的常见语法: 例如下面一段代 ...
- css选择器用法,使用css定位元素,css和xpath元素定位的区别
css定位元素 1.什么是css? CSS(Cascading Style Sheets)层叠样式表,是一种语言,用来描述html或者xml的显示样式.在css语言中有css选择器,在selenium ...
随机推荐
- ASM:《X86汇编语言-从实模式到保护模式》第16章:Intel处理器的分页机制和动态页面分配
第16章讲的是分页机制和动态页面分配的问题,说实话这个一开始接触是会把人绕晕的,但是这个的确太重要了,有了分页机制内存管理就变得很简单,而且能直接实现平坦模式. ★PART1:Intel X86基础分 ...
- MVC中使用Action全局过滤器出现:网页无法正常运作 将您重定向的次数过多。解决办法
前言当我们访问某个网站的时候需要检测用户是否已经登录(通过Session是否为null),我们知道在WebForm中可以定义一个BasePage类让他继承System.Web.UI.Page,重写它的 ...
- OUC校园导游
大二专业课太多,都没有好好的在博客上面做笔记,以备后面用的时候可以查找看一下,下面是写的不是完全正确的与图相关的代码~~希望指正~~ /* Name: Copyright: Author:Hxm Da ...
- ajax提交form表单资料详细汇总
一.ajax提交form表单和不同的form表单的提交主要区别在于,ajax提交表单是异步提交的,而普通的是同步提交的表单.通过在后台与服务器进行少量数据交换,ajax 可以使网页实现异步更新.这意味 ...
- 全选、取消、2级 checkbox的选中切换
需求:点击父级checkbox的时候,子级出现全选或全取消:点击子级时,如:子级都是在未选中时,点击某一个子级,则父级选中:如:子级中只有一个选中状态(其他子级都是未选中),点击该子级,则父级也改为未 ...
- 【Python】 属性的 get 与 set 方法
在C#里面,属性的get 与 set 非常简单方便. public class bird { public int age { get;set; } public bool isadult { get ...
- 【翻译】ASP.NET MVC 5属性路由(转)
转载链接:http://www.cnblogs.com/thestartdream/p/4246533.html 原文链接:http://blogs.msdn.com/b/webdev/archive ...
- Memcached vs Redis
Memcached和Redis哪一个能有更好的表现? Redis可以看作是Memcached的超集,这让Redis不仅仅可以用来当缓存,也可以作为实际的数据存储. 强大的数据结构以及操作命令. 默认持 ...
- ubuntu下安装myeclipse 并设置快捷键
官网下载:http://www.myeclipseide.com/ 安装myeclipse ctrl+alt+t打开终端,切换到myeclipse所在路径: -$ cd 下载/ 设置myeclipse ...
- 简单的SQL联表更新
UPDATE dbo.bankinfo1 SET bankinfo1.BankName=BankInfo.BankName FROM BankInfo where bankinfo1.banknumb ...