CSS选择器语法&示例

CSS3 选择器

在 CSS 中,选择器是一种模式,用于选择需要添加样式的元素。

"CSS" 列指示该属性是在哪个 CSS 版本中定义的。(CSS1、CSS2 还是 CSS3。)

选择器 例子 例子描述 CSS
.class .intro 选择 class="intro" 的所有元素。 1
#id #firstname 选择 id="firstname" 的所有元素。 1
* * 选择所有元素。 2
element p 选择所有 <p> 元素。 1
element,element div,p 选择所有 <div> 元素和所有 <p> 元素。 1
element element div p 选择 <div> 元素内部的所有 <p> 元素。 1
element>element div>p 选择父元素为 <div> 元素的所有 <p> 元素。 2
element+element div+p 选择紧接在 <div> 元素之后的所有 <p> 元素。 2
[attribute] [target] 选择带有 target 属性所有元素。 2
[attribute=value] [target=_blank] 选择 target="_blank" 的所有元素。 2
[attribute~=value] [title~=flower] 选择 title 属性包含单词 "flower" 的所有元素。 2
[attribute|=value] [lang|=en] 选择 lang 属性值以 "en" 开头的所有元素。 2
:link a:link 选择所有未被访问的链接。 1
:visited a:visited 选择所有已被访问的链接。 1
:active a:active 选择活动链接。 1
:hover a:hover 选择鼠标指针位于其上的链接。 1
:focus input:focus 选择获得焦点的 input 元素。 2
:first-letter p:first-letter 选择每个 <p> 元素的首字母。 1
:first-line p:first-line 选择每个 <p> 元素的首行。 1
:first-child p:first-child 选择属于父元素的第一个子元素的每个 <p> 元素。 2
:before p:before 在每个 <p> 元素的内容之前插入内容。 2
:after p:after 在每个 <p> 元素的内容之后插入内容。 2
:lang(language) p:lang(it) 选择带有以 "it" 开头的 lang 属性值的每个 <p> 元素。 2
element1~element2 p~ul 选择前面有 <p> 元素的每个 <ul> 元素。 3
[attribute^=value] a[src^="https"] 选择其 src 属性值以 "https" 开头的每个 <a> 元素。 3
[attribute$=value] a[src$=".pdf"] 选择其 src 属性以 ".pdf" 结尾的所有 <a> 元素。 3
[attribute*=value] a[src*="abc"] 选择其 src 属性中包含 "abc" 子串的每个 <a> 元素。 3
:first-of-type p:first-of-type 选择属于其父元素的首个 <p> 元素的每个 <p> 元素。 3
:last-of-type p:last-of-type 选择属于其父元素的最后 <p> 元素的每个 <p> 元素。 3
:only-of-type p:only-of-type 选择属于其父元素唯一的 <p> 元素的每个 <p> 元素。 3
:only-child p:only-child 选择属于其父元素的唯一子元素的每个 <p> 元素。 3
:nth-child(n) p:nth-child(2) 选择属于其父元素的第二个子元素的每个 <p> 元素。 3
:nth-last-child(n) p:nth-last-child(2) 同上,从最后一个子元素开始计数。 3
:nth-of-type(n) p:nth-of-type(2) 选择属于其父元素第二个 <p> 元素的每个 <p> 元素。 3
:nth-last-of-type(n) p:nth-last-of-type(2) 同上,但是从最后一个子元素开始计数。 3
:last-child p:last-child 选择属于其父元素最后一个子元素每个 <p> 元素。 3
:root :root 选择文档的根元素。 3
:empty p:empty 选择没有子元素的每个 <p> 元素(包括文本节点)。 3
:target #news:target 选择当前活动的 #news 元素。 3
:enabled input:enabled 选择每个启用的 <input> 元素。 3
:disabled input:disabled 选择每个禁用的 <input> 元素 3
:checked input:checked 选择每个被选中的 <input> 元素。 3
:not(selector) :not(p) 选择非 <p> 元素的每个元素。 3
::selection ::selection 选择被用户选取的元素部分。 3

1.大家在使用selenium元素定位的时候,通常更多使用的是XPATH,css定位方式用得比较少,但有时候css定位方式还是有一些优势的,

优势1:一般情况下定位速度要比XPATH快

优势2:语法要比XPATH更简洁

常见语法


*


通用元素选择器,匹配任何元素


E


标签选择器,匹配所有使用E标签的元素


.info


class选择器,匹配所有class属性中包含info的元素


#footer


id选择器,匹配所有id属性等于footer的元素


E,F


多元素选择器,同时匹配所有E元素或F元素,E和F之间用逗号分隔


E F


后代元素选择器,匹配所有属于E元素后代的F元素,E和F之间用空格分隔


E > F


子元素选择器,匹配所有E元素的子元素F


E + F


毗邻元素选择器,匹配紧随E元素之后的同级元素F (只匹配第一个)


E ~ F


同级元素选择器,匹配所有在E元素之后的同级F元素


E[att=‘val‘]


属性att的值为val的E元素 (区分大小写)


E[att^=‘val‘]


属性att的值以val开头的E元素 (区分大小写)


E[att$=‘val‘]


属性att的值以val结尾的E元素 (区分大小写)


E[att*=‘val‘]


属性att的值包含val的E元素 (区分大小写)


E[att1=‘v1‘][att2*=‘v2‘]


属性att1的值为v1,att2的值包含v2 (区分大小写)


E:contains(‘xxxx‘)


内容中包含xxxx的E元素


E:not(s)


匹配不符合当前选择器的任何元素

例如这样一段html代码的网页

<div class="formdiv">

<form name="fnfn">

<input name="username" type="text"></input>

<input name="password" type="text"></input>

<input name="continue" type="button"></input>

<input name="cancel" type="button"></input>

<input value="SYS123456" name="vid" type="text">

<input value="ks10cf6d6" name="cid" type="text">

</form>

<div class="subdiv">

<ul id="recordlist">

<p>Heading</p>

<li>Cat</li>

<li>Dog</li>

<li>Car</li>

<li>Goat</li>

</ul>

</div>

</div>

匹配示例:


locator


匹配


css=div

css=div.formdiv


<div class="formdiv">


css=#recordlist

css=ul#recordlist


<ul id="recordlist">


css=div.subdiv p

css=div.subdiv > ul > p


<p>Heading</p>


css=form + div


<div class="subdiv">


css=p + li

css=p ~ li


二者定位到的都是 <li>Cat</li>

但是storeCssCount的时候,前者得到1,后者得到4


css=form > input[name=username]


<input name="username">


css=input[name$=id][value^=SYS]


<input value="SYS123456" name="vid" type="hidden">


css=input:not([name$=id][value^=SYS])


<input name="username" type="text"></input>


css=li:contains(‘Goa‘)


<li>Goat</li>


css=li:not(contains(‘Goa‘))


<li>Cat</li>

2.css中的结构性定位

结构性定位就是根据元素的父子、同级中位置来定位,css3标准中有定义一些结构性定位伪类如nth-of-type,nth-child,但是使用起来语法很不好理解,这里就不做介绍了。

Selenium中则是采用了来自Sizzle的css3定位扩展,它的语法更加灵活易懂

Sizzle Css3的结构性定位语法


E:nth(n)

E:eq(n)


在其父元素中的E子元素集合中排在第n+1个的E元素 (第一个n=0)


E:first


在其父元素中的E子元素集合中排在第1个的E元素


E:last


在其父元素中的E子元素集合中排在最后1个的E元素


E:even


在其父元素中的E子元素集合中排在偶数位的E元素 (0,2,4…)


E:odd


在其父元素中的E子元素集合中排在奇数的E元素 (1,3,5…)


E:lt(n)


在其父元素中的E子元素集合中排在n位之前的E元素 (n=2,则匹配0,1)


E:gt(n)


在其父元素中的E子元素集合中排在n位之后的E元素 (n=2,在匹配3,4)


E:only-child


父元素的唯一一个子元素且标签为E


E:empty


不包含任何子元素的E元素,注意,文本节点也被看作子元素

匹配示例:

例如还是段的代码

<div class="subdiv">

<ul id="recordlist">

<p>Heading</p>

<li>Cat</li>

<li>Dog</li>

<li>Car</li>

<li>Goat</li>

</ul>

</div>


locator


匹配


css=ul > li:nth(0)


<li>Cat</li>


css=ul > *:nth(0)

css=ul > :nth(0)


<p>Heading</p>


css=ul > li:first


<li>Cat</li>


css=ul > :first


<p>Heading</p>


css=ul > *:last

css=ul > li:last


<li>Goat</li>


css=ul > li:even


Cat, Car


css=ul > li:odd


Dog, Goat


css=ul > :even


<p>Heading</p>


css=ul > p:odd


[error] not found


css=ul > li:lt(2)


<li>Cat</li>


css=ul > li:gt(2)


<li>Goat</li>


css=ul > li:only-child

css=ul > :only-child

css=ul > *:only-child


[error] not found (ul没有only-child)


css=div.subdiv > :only-child


<ul id="recordlist">

… … … …

</ul>

原文地址:https://www.cnblogs.com/songzhenhua/p/10260992.html

时间: 2024-10-10 18:28:03

CSS选择器语法&示例的相关文章

html之css选择器语法学习笔记

相关内容: css选择器的用法: 选择器的语法 标签选择器 类选择器 id选择器 选择器的分组 嵌套选择 属性选择器 子标签选择器 相邻兄弟选择器 参考资料:w3school 首发时间:2018-03-02 23:54 css选择器的用法: css选择器的语法:css选择器的定义有两部分组成,一个是选择器,一个是样式定义 标签选择器(直接根据标签来选择): h1 {color:red; font-size:14px;} p { color: #ff0000; } body { color: #0

css - 选择器语法入门

选择器 css里有三种选择器(定位到具体元素的语法) 1 标签选择器 article { margin-bottom: 40px; } 如上,直接写出article就是标签选择器.对应的html为<article>content</article>. 2 class选择 .sitename { float: left; } 形如.sitename为class选择.在html里为<div class='sitename'>content</div>. 3 id

CSS 选择器语法参考手册

转自:http://www.w3school.com.cn/cssref/css_selectors.asp CSS3 选择器 在 CSS 中,选择器是一种模式,用于选择需要添加样式的元素. "CSS" 列指示该属性是在哪个 CSS 版本中定义的.(CSS1.CSS2 还是 CSS3.) 选择器 例子 例子描述 CSS .class .intro 选择 class="intro" 的所有元素. 1 #id #firstname 选择 id="firstna

CSS选择器(CSS终极指南阅读回顾)

CSS选择器语法 CSS样式表有选择器和生命块组成.声明块有属性名.属性值.中间有冒号分开,后面分号结尾. 选择器组操作 可以把几个选择器组合到一块,来快速选取操作的元素.例如,h1,h2,h3,h4,h5,h6{color:red;} *通配符选择器,选择所有的元素. 标签选择器 类选择器 由点号加名字组成.需要html标签添加class属性. 类可以结合标签选择器使用:p.class1. 两个类可以.class1.class2的方式使用,选择class="class1 class2"

CSS(1)---css语法、css选择器

CSS(1)---css语法.css选择器 一.CSS语法 1.CSS语法 CSS 规则由两个主要的部分构成:选择器以及一条或多条声明. 属性 是您希望设置的 样式属性.每个属性有一个属性值.属性和属性值被冒号分开. 示例 <!-- 这行代码的作用是将 h1 元素内的文字颜色定义为红色,同时将字体大小设置为 14 像素 --> h1 {color:red; font-size:14px;} <!-- 在这里,h1 是选择器,color 和 font-size 是属性,red 和 14px

Unit02: CSS 概述 、 CSS 语法 、 CSS 选择器 、 CSS声明

Unit02: CSS 概述 . CSS 语法 . CSS 选择器 . CSS声明 my.css p { color: yellow; } demo1.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> <!-- 2.内部样式:在head元素内部的style标签内 写样式,这种样式

CSS基本语法和选择器

CSS是指层叠样式表(cascading style sheets),样式定义如何显示HTML元素,是真正能够做到网页表现和内容分类的一种语言. [1]CSS基本语法 [2]CSS两种结合方式 [3]几种选择器 基本语法 基本语法也就两种,在head中使用选择器选择,然后在body中使用,如下中的样式属性键:样式属性值1 样式属性值2...是多个属性值的连用. <!DOCTYPE html> <html> <head> <title>02-结合方式2.htm

css基础语法,简单选择器,文本样式2018/4/26

MDN-CSS 介绍 MDN-CSS如何工作 MDN-CSS 语法 MDN-选择器 MDN-简单选择器 MDN-属性选择器 MDN-基本文本和字体样式 color font-family font-style font-weight font-size text-align text-decoration text-indent line-height text-shadow 验证 今天代码部分其实比较简单,主要是多尝试,学习之后,回顾以下自己是否已经掌握以下概念: 什么是CSS,CSS是如何工

Day48:HTML(form标签)、CSS选择器

一.表单标签<form> 功能:表单用于向服务器传输数据,从而实现用户与Web服务器的交互. 表单能够包含input系列标签,比如文本字段.复选框.单选框.提交按钮等等. 表单还可以包含textarea.select.fieldset和 label标签. 表单属性 action: 表单提交到哪.一般指向服务器端一个程序,程序接收到表单提交过来的数据(即表单元素值)作相应处理,比如https://www.sogou.com/web method: 表单的提交方式 post/get默认取值就是ge