title | date | icon | category | tag | ||||
---|---|---|---|---|---|---|---|---|
选择器 |
2022-08-03 |
selector |
|
|
CSS 中可以通过选择器来选中 HTML 文档中的元素。
CSS 的选择器一共分为四种,分别是:
- 基本选择器
- 选择符
- 伪类
- 伪元素
基本选择器共五个,是指平时使用的通配符选择器、标签选择器、ID 选择器、类选择器、属性选择器。
/* 通配符选择器,效率较低 */
* {}
/* 标签选择器 */
body {}
/* ID 选择器 */
#id {}
/* 类选择器 */
.class {}
/* 属性选择器 */
[attr=val] {} /* 属性等于某个值 */
[attr] {} /* 拥有某一个属性 */
::: tip
一个元素的 id 唯一,不能重复。
:::
选择符一共有五个,分别如下:
/* 后代关系 */
.container img {}
/* 父子关系 */
ol > li {}
/* 相邻兄弟关系 */
button + button {}
/* 普通兄弟关系 */
button ~ button {}
/* 列(不常见) */
.col || td {}
::: normal-demo 后代关系,以空格分开,会选择所有的后代
<div class="box">
<div>
<span>我会被选中</span>
</div>
</div>
<div class="box">
<span>我也会被选中</span>
</div>
.box span {
color: red;
}
:::
::: normal-demo 父子关系,以 > 分开,选择直接相邻子代
<div class="box">
<div>
<span>我不会被选中</span>
</div>
</div>
<div class="box">
<span>我会被选中</span>
</div>
.box > span {
color: red;
}
:::
::: normal-demo 相邻兄弟关系,以 + 分开,选择后续直接相邻兄弟
<div>one</div>
<div class="box">two</div>
<div>three</div>
<div>four</div>
.box + div {
color: red;
}
:::
::: normal-demo 普通兄弟关系,以 ~ 分开,选择后续所有兄弟
<div>one</div>
<div class="box">two</div>
<div>three</div>
<div>four</div>
.box ~ div {
color: red;
}
:::
伪类的特征是前面会有一个冒号 :
,通常与浏览器行为和用户行为相关联,代表元素的某种状态,不会产生新的元素。
以动态伪类为例:
a:link
未访问的链接;a:visited
已访问的链接a:hover
鼠标移动到链接上a:active
激活的链接(鼠标在链接上长按未松开)
::: normal-demo 动态伪类
<a href="#伪类">尝试点击、悬停、长按</a>
a:link {
color: red;
}
a:visited {
color: yellowgreen;
}
a:hover {
color: blue;
cursor: pointer;
}
a:active {
color: purple;
}
:::
::: tip 使用注意
:hover
必须放在:link
和:visited
后面才能生效;:active
必须放在:hover
后面才能生效;
因此建议的编写顺序为::link
、:visited
、:hover
、:active
。
除了 <a>
元素外,:hover
、:active
也能用在其他元素上。
直接给 <a>
元素设置样式,相当于给 <a>
元素所有状态伪类都设置了相同的样式。
:::
::: info
:::
伪元素的特征是前面会有两个冒号 ::
,允许你对被选择元素的特定部分修改样式,但是这些元素实际上不会在文档中生产,只会在外部显示可见。
一些常见的伪元素:
::before
用来创建一个伪元素,作为已选中元素的第一个子元素,通常会配合content
属性来为该元素添加装饰内容,默认是行内元素;::after
用来创建一个伪元素,作为已选中元素的最后一个子元素,通常会配合content
属性来为该元素添加装饰内容,默认是行内元素;::first-letter
会选中某块级元素第一行的第一个字母,并且文字所处的行之前没有其他内容(如图片和内联的表格);::first-line
会选中某块级元素的第一行。
::: normal-demo ::before
<p>代办列表,尝试点击</p>
<ul>
<li>Buy milk</li>
<li>Take the dog for a walk</li>
<li>Exercise</li>
<li>Write code</li>
<li>Play music</li>
<li>Relax</li>
</ul>
ul {
margin-left: -2em;
}
li {
list-style-type: none;
position: relative;
margin: 2px;
padding: 0.5em 0.5em 0.5em 2em;
background: lightgrey;
font-family: sans-serif;
}
li.done {
background: #CCFF99;
}
li.done::before {
content: '';
position: absolute;
border-color: #009933;
border-style: solid;
border-width: 0 0.3em 0.25em 0;
height: 1em;
top: 1.3em;
left: 0.6em;
margin-top: -1em;
transform: rotate(45deg);
width: 0.5em;
}
var list = document.querySelector('ul');
list.addEventListener('click', function(ev) {
if( ev.target.tagName === 'LI') {
ev.target.classList.toggle('done');
}
}, false);
:::
::: normal-demo ::after
<p>
我们有一些 <span data-descr="文字">文字</span> 有一些
<span data-descr="提示">提示</span>。<br />
把鼠标放上去<span data-descr="看看">看看</span>。
</p>
span[data-descr] {
position: relative;
text-decoration: underline;
color: #00F;
cursor: help;
}
span[data-descr]:hover::after {
content: attr(data-descr);
position: absolute;
left: 0;
top: 24px;
min-width: 200px;
border: 1px #aaaaaa solid;
border-radius: 10px;
background-color: #ffffcc;
padding: 5px;
color: #000000;
font-size: 14px;
z-index: 1;
}
:::
::: normal-demo ::first-letter
<p>使每段开头的第一个字母变红变大</p>
p::first-letter {
color: red;
font-size: 130%;
}
:::
::: normal-demo ::first-line
<p>使段落的第一行变大,比如我有一个多行文字,比如我有一个多行文字,比如我有一个多行文字,比如我有一个多行文字,比如我有一个多行文字。</p>
p::first-line {
font-size: 130%;
}
:::
::: info
:::
如果有多个使用相同样式的 CSS 选择器,那么这些单独的选择器可以被混编为一个「选择器列表」,这样,规则就可以应用到所有的单个选择器上了。
h1, .special {
color: blue;
}
/* 等价于 */
h1 {
color: blue;
}
.special {
color: blue;
}
::: warning
当使用选择器列表时,如果任何一个选择器无效 (存在语法错误),那么整条规则都会被忽略。
:::
CSS 优先级可以分为 0~5 级共 6 个等级,前 4 个等级由选择器决定,后 2 个等级由书写形式和特定语法决定。
优先级大小可以由数值计算出,出现一个 0 级选择器,优先值数值加 0,1 级选择器加 1,2 级选择器加 10,3 级选择器加 100,以此类推。
0 级优先级包括:通配符选择器、选择符(5 种)和逻辑组合伪类(:not()
:is()
:where
)。
1 级优先级就是标签选择器。
2 级优先级包括:类选择器、属性选择器和其他伪类。
3 级优先级为 ID 选择器。
4 级优先级为内联样式。
5 级优先级为 !important
。