CSS(层叠样式表)是网页样式设计的核心技术之一,通过选择器,我们可以精准定位并施加样式于HTML文档中的各个元素。本文将详细介绍CSS中的一些常见选择器,并配以实例代码进行演示。
1. 基本选择器
1.1 标签选择器
标签选择器是最基础的选择器,通过HTML标签名称选取相应的元素。
css
/* 为所有的段落元素设置字体颜色 */
p {
color: red;
}
1.2 类选择器
类选择器以.
开头,后面跟随类名。它可以应用于具有该类名的任何元素。
css
/* 为类名为'highlight'的元素设置背景色 */
.highlight {
background-color: yellow;
}
ini
<p class="highlight">这段文字会变成黄色背景。</p>
1.3 ID选择器
ID选择器以#
开头,后面紧跟ID名。每个ID在文档中应是唯一的。
arduino
/* 为ID为'main-title'的元素设置字号 */
#main-title {
font-size: 24px;
}
bash
<h1 id="main-title">主标题</h1>
2. 属性选择器
属性选择器根据HTML元素的属性及其值来定位元素。
css
/* 为href属性值包含'example'的a标签设置颜色 */
a[href*='example'] {
color: blue;
}
3. 伪类选择器
伪类选择器用于选择元素的一种特殊状态或条件。
3.1 链接伪类选择器
例如,:hover
用于鼠标悬停时的状态。
css
/* 当鼠标悬浮在链接上时,链接颜色变为绿色 */
a:hover {
color: green;
}
3.2 结构伪类选择器
:first-child
、:last-child
等选择器用于根据元素在父元素中的位置选择。
css
/* 选择第一个段落元素 */
p:first-child {
font-weight: bold;
}
4. 通配选择器与组合选择器
4.1 通配选择器 *
匹配任何元素。
css
/* 设置文档中所有元素的默认字体大小 */
* {
font-size: 16px;
}
4.2 组合选择器
组合选择器包括后代选择器、子元素选择器、相邻兄弟选择器和一般兄弟选择器。
- 后代选择器:以空格分隔,选择某个元素的所有后代元素。
css
/* 选择id为container的元素内的所有段落元素 */
#container p {
color: purple;
}
- 子元素选择器:以
>
分隔,只选择直接子元素。
css
/* 选择作为main直接子元素的div元素 */
main > div {
margin-bottom: 1em;
}
- 相邻兄弟选择器
+
:选择紧随其后的同级元素。
css
/* 选择紧随h1之后的第一个p元素 */
h1 + p {
text-indent: 2em;
}
- 一般兄弟选择器
~
:选择其后所有同级元素。
css
/* 选择所有位于h1之后的同级p元素 */
h1 ~ p {
font-style: italic;
}
5. 层级选择器
层级选择器,又称深度选择器,以>
符号表示直接子元素选择,可以深入到DOM树的任意层级进行选择。
css
/* 选择div元素下直接嵌套的所有span元素 */
div > span {
color: orange;
}
6. 伪元素选择器
伪元素选择器用于选择并样式化文档中某些特定类型的虚拟内容,如:before 和 :after 可以生成内容。
css
/* 在每个段落前插入一个红色感叹号 */
p::before {
content: "!";
color: red;
}
7. 属性选择器进阶
除了前面提到的基本属性选择器,还有更复杂的属性选择器形式。
[att^=value]
:选择属性att的值以value开头的元素。
css
/* 选择lang属性值以'en'开头的所有元素 */
*[lang^='en'] {
font-family: sans-serif;
}
[att$=value]
:选择属性att的值以value结尾的元素。
css
/* 选择class属性以'-active'结尾的元素 */
[class$='-active'] {
background-color: lightblue;
}
[att*=value]
:选择属性att的值包含子串value的元素。
css
/* 选择title属性中包含'important'字样的元素 */
*[title*='important'] {
border: 1px solid red;
}
8. 选择器列表与组合
在一个声明块前可以列出多个选择器,用逗号 ,
分隔,这样可以一次性为多个选择器设置相同的样式。
css
/* 为所有的段落和标题元素设置相同的字体颜色 */
p, h1, h2, h3 {
color: darkslategray;
}
9. 选择器权重与优先级
在CSS中,不同选择器的优先级不同。ID选择器的优先级最高,类选择器次之,标签选择器最低。组合选择器的权重按其包含的选择器的总权重计算。当权重相同时,后来的样式会覆盖先前的样式。
总结
总结来说,熟练掌握并灵活运用CSS的各种选择器,是编写高效、简洁且易于维护CSS代码的关键所在。通过精准定位目标元素并施加恰当的样式,可以大大提高网页设计的灵活性和美感。同时,理解和掌握选择器的优先级和层叠规则,能够帮助我们更准确地预测和控制样式的最终呈现效果。