此页面由社区从英文翻译而来。了解更多并加入 MDN Web Docs 社区。

View in English Always switch to English

line-height

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since ⁨2015年7月⁩.

line-height CSS 属性用于设置多行元素的空间量,如多行文本的间距。对于块级元素,它指定元素行盒(line boxes)的最小高度。对于非可替换的 inline 元素,它用于计算行盒(line box)的高度。

尝试一下

line-height: normal; 
line-height: 2.5; 
line-height: 3em; 
line-height: 150%; 
line-height: 32px; 
<section id="default-example"> <div class="transition-all" id="example-element"> Far out in the uncharted backwaters of the unfashionable end of the western spiral arm of the Galaxy lies a small unregarded yellow sun. </div> </section> 
#example-element { font-family: Georgia, sans-serif; max-width: 200px; } 

语法

css
/* Keyword value */ line-height: normal; /* Unitless values: use this number multiplied by the element's font size */ line-height: 3.5; /* <length> values */ line-height: 3em; /* <percentage> values */ line-height: 34%; /* Global values */ line-height: inherit; line-height: initial; line-height: unset; 

line-height 属性被指定为以下任何一个:

取值

normal

取决于用户代理。桌面浏览器(包括 Firefox)使用默认值,约为 1.2,这取决于元素的 font-family

<number>(无单位)

该属性的应用值是这个无单位<数字>乘以该元素的字体大小。计算值与指定的 <number> 值相同。大多数情况下,这是设置 line-height推荐方法,不会在继承时产生不确定的结果。

<length>

指定用于计算行向盒高度的<长度>值。以 em 为单位的值可能会产生不确定的结果(见下面的示例)。

<percentage>

与元素自身的字体大小有关。计算值是给定的百分比值乘以元素计算出的字体大小。<percentage> 值可能会带来不确定的结果(见下面第二个示例)。

形式化语法

line-height = 
normal |
<number [0,∞]> |
<length-percentage [0,∞]>

<length-percentage> =
<length> |
<percentage>

示例

基本示例

css
/* 理论上,以下所有规则拥有相同的行高 */ div { line-height: 1.2; font-size: 10pt; } /* 无单位数值 number/unitless */ div { line-height: 1.2em; font-size: 10pt; } /* 长度 length */ div { line-height: 120%; font-size: 10pt; } /* 百分比 percentage */ div { font: 10pt/1.2 Georgia, "Bitstream Charter", serif; } /* font 简写属性 font shorthand */ 

为了简便,可以通过 font 简写来设置 line-height,但这要求在使用该简写属性时同时设置 font-family 属性。

推荐在设置 line-height 时使用无单位数值

这个示例说明了为什么给 line-height 赋值时使用 <数字> 值比使用 <长度> 更好。我们会到用两个 <div> 元素。第一个 div 为绿色边框,使用无单位的 line-height值。第二个 div 带红色边框,使用 em 定义 line-height 的值。

CSS

css
.green { line-height: 1.1; border: solid limegreen; } .red { line-height: 1.1em; border: solid red; } h1 { font-size: 30px; } .box { width: 18em; display: inline-block; vertical-align: top; font-size: 15px; } 

HTML

html
<div class="box green"> <h1>Avoid unexpected results by using unitless line-height.</h1> length and percentage line-heights have poor inheritance behavior ... </div> <div class="box red"> <h1>Avoid unexpected results by using unitless line-height.</h1> length and percentage line-heights have poor inheritance behavior ... </div> <!-- The first <h1> line-height is calculated from its own font-size (30px × 1.1) = 33px --> <!-- The second <h1> line-height results from the red div's font-size (15px × 1.1) = 16.5px, probably not what you want --> 

结果

无障碍方面

主段落内容的 line-height 至少应为 1.5。这将有助于改善低可视条件下的体验,也对认知阻碍者,如阅读困难者,有帮助。如果文字的大小要随页面的缩放而变化,请使用无单位的值,以确保行高也会等比例缩放。

W3C Understanding WCAG 2.1

规范

Specification
CSS Inline Layout Module Level 3
# line-height-property
初始值normal
适用元素所有元素. It also applies to ::first-letter and ::first-line.
是否是继承属性
Percentagesrefer to the font size of the element itself
计算值对于百分比和长度值,其为绝对长度,否则为指定值
动画类型数字或长度均可

浏览器兼容性

参见