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选择器规则优先级很简单,每个选择器本身有优先级,越具体优先级越高