使用text-indent实现段落首行缩进,推荐用em单位;::first-line用于第一行样式修饰但不能实现缩进。1. text-indent专用于首行缩进,支持em、px等单位;2. ::first-line可设置颜色、字体等,不可替代text-indent;3. 可结合使用:text-indent控制缩进,::first-line美化首行样式,各司其职提升排版效果。

在CSS中实现段落首行缩进,最常用的方法是使用 text-indent 属性。虽然 ::first-line 伪元素可以对段落的第一行设置样式(如颜色、字体等),但它不能直接用于实现“缩进”效果。下面详细介绍如何正确使用这两个特性来控制段落排版。
使用 text-indent 实现首行缩进
text-indent 是专门用来控制块级元素首行缩进的CSS属性,适用于 、 示例: 这样,每个段落的首行会向内缩进2个字符的位置,符合中文排版习惯。你也可以使用像素(px)、百分比(%)等单位。 立即学习“前端免费学习笔记(深入)”; ::first-line 用于选中块级元素第一行的文本,常用于设置第一行的字体、颜色、粗细等样式。 示例: 虽然它操作的是“第一行”,但无法替代 text-indent 来实现缩进。如果你尝试在 ::first-line 中使用 text-indent,部分浏览器可能不支持或行为不一致,因此不推荐这样做。 实际开发中,你可以同时使用两者达到更丰富的排版效果: p::first-line {
font-variant: small-caps; / 首行小型大写字母 /
}
这样既实现了标准的首行缩进,又让第一行具有特殊样式,增强可读性和美观性。 基本上就这些——想缩进用 text-indent,想美化第一行用 ::first-line,两者各司其职,配合使用效果更佳。p {
text-indent: 2em; /* 缩进两个汉字宽度 */
}
::first-line 伪元素的作用与限制
p::first-line {
color: red;
font-weight: bold;
}
结合使用场景建议
p {
text-indent: 2em;
text-align: justify;
}










