CSS选择器
- 基础选择器
- 组合选择器
- 属性选择器
- 伪类选择器
- 伪元素选择器
基础选择器
选择器 | 例子 | 含义 |
---|---|---|
* | * | 通用元素选择器,匹配所有元素。(匹配范围太广,很少用到) |
#id | #element-id | id选择器,匹配id为element-id 元素 |
.class | .element-class | 类选择器,匹配class包含(不是等于)element-class 元素 |
element | p | 标签选择器,匹配标签类型为p 的所有元素 |
* {
font-family: '微软雅黑';
}
#element-id {
color: red;
}
.element-class {
background: black;
}
p {
font-size: 16px;
line-height: 20px;
}
组合选择器
以下 E,F 都为合法的选择器
选择器 | 例子 | 含义 |
---|---|---|
E,F | div,p | 多元素选择器,用, 分隔,同时匹配元素E或元素F,例子中的含义为匹配所有的<div> 和<p> |
E F | div p | 后代选择器,用空格分隔,匹配E元素所有的后代(不只是子元素、子元素向下递归)符合 F 的元素,例子中的含义为匹配所有的在<div> 下的<p> |
E>F | div>p | 直接子元素选择器,用> 分隔,匹配E元素的所有直接子元素,例子中的含义为匹配所有<div> 的直接子元素且是<p> |
E+F | div+p | 直接相邻选择器,匹配E元素之后的相邻的同级元素F,例子中的含义为匹配紧接在 <div> 之后的所有 <p> 元素 |
E~F | div~p | 普通相邻选择器(弟弟选择器),匹配E元素之后的同级元素F(无论直接相邻与否),例子中的含义为匹配紧<div> 之后的所有 <p> 元素 |
EF | .class1.class2 | EF 连写,匹配同时满足 E 和 F 的元素,例子中的含义为匹配 class 中同时有 class1 和 class2 的元素 |
属性选择器
以下 E 为合法的选择器,attr 为合法属性
选择器 | 例子 | 含义 |
---|---|---|
[attr] | input[disabled] | 匹配所有具有属性attr的元素,例子中的含义为选择所有有disabled 属性的<input> |
[attr = value] | [id=did] | 匹配属性attr值为value的元素,例子等价于#did |
[attr ~= value] | [class~=dclass] | 匹配所有属性attr具有多个空格分隔、其中一个值等于value的元素,例子等价于.dclass |
[attr ^= value] | div[class^=d] | 匹配属性attr的值以value开头的元素,例子可以匹配<div class="dclass"> |
[attr $= value] | div[class$=d] | 匹配属性attr的值以value结尾的元素,例子可以匹配<div class="classd"> |
[attr *= value] | div[class*=d] | 匹配属性attr的值包含value的元素,例子可以匹配<div class="somedsome"> |
伪类选择器
以下 E 为合法的选择器
选择器 | 含义 |
---|---|
E:first-child | 匹配元素E的第一个子元素 |
E:link | 匹配所有未被点击的链接 |
E:visited | 匹配所有已被点击的链接 |
E:active | 匹配鼠标已经其上按下、还没有释放的E元素 |
E:hover | 匹配鼠标悬停其上的E元素 |
E:focus | 匹配获得当前焦点的E元素 |
E:enabled | 匹配表单中可用的元素 |
E:disabled | 匹配表单中禁用的元素 |
E:checked | 匹配表单中被选中的radio或checkbox元素 |
E:nth-child(n) | 匹配其父元素的第n个子元素,第一个编号为1 |
E:nth-last-child(n) | 匹配其父元素的倒数第n个子元素,第一个编号为1 |
E:nth-of-type(n) | 与:nth-child()作用类似,但是仅匹配使用同种标签的元素 |
E:nth-last-of-type(n) | 与:nth-last-child() 作用类似,但是仅匹配使用同种标签的元素 |
E:last-child | 匹配父元素的最后一个子元素,等同于:nth-last-child(1) |
E:first-of-type | 匹配父元素下使用同种标签的第一个子元素,等同于:nth-of-type(1) |
E:last-of-type | 匹配父元素下使用同种标签的最后一个子元素,等同于:nth-last-of-type(1) |
E:only-child | 匹配父元素下仅有的一个子元素,等同于:first-child:last-child或 :nth-child(1):nth-last-child(1) |
E:only-of-type | 匹配父元素下使用同种标签的唯一一个子元素,等同于:first-of-type:last-of-type或 :nth-of-type(1):nth-last-of-type(1) |
E:empty | 匹配一个不包含任何子元素的元素,文本节点也被看作子元素 |
E:not(selector) | 匹配不符合当前选择器的任何元素 |
其中 N 的取值可以为
- 1,2,3,4,5
- 2n+1, 2n, 4n-1
- odd, even
伪元素选择器
选择器 | 含义 |
---|---|
E:first-line | 匹配E元素内容的第一行 |
E:first-letter | 匹配E元素内容的第一个字母 |
E:before | 在E元素之前插入生成的内容 |
E:after | 在E元素之后插入生成的内容 |
选择器优先级
如果多条规则作用于同一个元素上,且定义的相同属性的不同值,比如
<style>
.text {color: red;}
p {color: black;}
</style>
<p class="text">Text</p>
这种场景下,p
元素文本颜色应该是哪个呢?
这和我们日常生活中一样,市长说这事不行,省长说这事可以,自然是听省长的,CSS规则同样有优先级
CSS 优先级从高到低分别是
- 在属性后面使用
!important
会覆盖页面内任何位置定义的元素样式 - 作为style属性写在元素标签上的内联样式
- id选择器
- 类选择器
- 伪类选择器
- 属性选择器
- 标签选择器
- 通配符选择器
- 浏览器自定义
这样就可以看出来上面例子肯定使用id选择器的定义了。
但是对于一种复杂情况,CSS规则由多个选择器组成,我们该如何处理那?
#test p.class1 {...}
#test .class1.class2 {...}
这种场景该使用那条规则呢?
选择器特殊性/优先级
一个元素可能会被多个规则来选择,如何判断哪个规则更胜出,这就需要用到选择器特殊性。选择器特殊性也称为选择器优先级、选择器权重。
选择器的特殊性分成4个成分等级:a、b、c和d
- 如果样式是行内样式,那么a = 1
- b: ID选择器的总数
- c: 类、伪类和属性选择器的数量
- d: 元素选择器和伪元素选择器的数量
- 将a,b,c,d组成的一串数字进行比较,例如:1-0-0-0优先于0-2-0-7
与四位数比较大小从左到右顺序相同,但不同的是 0-0-1-0 比 0-0-0-13 优先级更高。
注意
- 通用选择器特殊性为0,计算特殊性时可忽略
- 如果两个规则的特殊性相同,那么后定义的规则优先
!important
用于声明重要声明,与非重要声明冲突时总是胜出- 内联样式优先级最高
- id选择器由于class选择器
特殊性练习示例:
选择器 | 特殊性 | 以10为基数的特殊性 |
---|---|---|
Style= "" | 1,0,0,0 | 1000 |
#wrapper #content {} | 0,2,0,0 | 200 |
#content .datePosted {} | 0,1,1,0 | 110 |
div#content {} | 0,1,0,1 | 101 |
#content {} | 0,1,0,0, | 100 |
p.comment .dateposted {} | 0,0,2,1 | 21 |
p.comment {} | 0,0,1,1 | 11 |
div p {} | 0,0,0,2 | 2 |
p {} | 0,0,0,1 | 1 |
这时候我们可以做个简单的加法运算,id选择器的权值为1000,class选择器为100,标签选择器为10,做一下运算(当然只是为了形象这么说,一万个class选择器加起来也不如一个id选择器优先级高)
同特殊性下的处理
这样我们就能得知第二条的规则优先级高一些,但是还有一种情况
#parent p.class1
div #child.class1
<div id="parent">
<p id="child" class="class1">
Text
</p>
</div>
按照我们刚才的方法计算,两个的权值时相同的,这时候应该用那条规则呢?简单来说一句话谁更具体用谁,也就是权值高的选择器作用的越具体优先级越高
我们可以看到两个选择器作用的元素都是p
标签,id选择器权值最高,第一条规则作用在了父元素上,第二条规则直接作用在了p
标签本身上,所以我们认为第二条选择器的优先级高
如果两个选择器规权值就是一样,我们改怎么判断呢? 后面的覆盖前面的!
div {color: #333;}
....
div {color: #666;}
这样div
文案的颜色明显会是#666
总而言之判断CSS选择器规则优先级很简单,每个选择器本身有优先级,越具体优先级越高