深入理解line-height

深入理解line-height

基本概念

行高、行距

行高是指文本行基线间的垂直距离。那什么是基线呢?记不记得vertical-align属性有个baseline值,这个baseline就是基线,也即当前字体当前字号中字母'x'的底部。看张“盗图”(选自下面的参考文章),其实我也修改了一下啦~

图片描述注意:倒数第二根是基线哦,最下面那根是底线,不是基线。

图中两条红线之间的距离就是行高(line-height),上一行的底线和下一行的顶线之间的距离就是行距,而同一行顶线和底线之间的距离是font-size的大小,行距的一半是半行距,半行距、font-size、line-height之间的关系看图片的右下角就一目了然了~

半行距 = (line-height - font-size)/2

当然,半行距也可能为负值(当line-height < font-size),这时候两行之间就会重叠,如下图所示:图片描述

4种box

要说的4种盒子分别是inline boxline boxcontent areacontaining box ~

  • inline box (内联盒子) 每个内联元素(span、em等)或者匿名内联元素(无标签包裹的文本)会生成一个内联盒子(或者匿名内联盒子),内联盒子是一个浏览器渲染模型中的一个概念,无法显示出来,内联盒子的高度等于font-size设定line-height时,内联盒子的高度不变,改变的是行距

  • line box (行框盒子) 行框盒子是指本行的一个虚拟的矩形框,由该行中行内框组成。行框盒子也是浏览器渲染模式中的一个概念,无法显示出来。例如当 p 元素出现在屏幕上时,它可能包含了多行内容,每行内容由多个内联元素组成(内联标签或者是包含文本的匿名内联元素),每一行都叫做一个 line-box。line-box 的高度是由它所有子元素的高度计算得出的。浏览器会计算这一行里每个子元素的高度(这个高度取的是子元素的line-height而不是inline box的height,也即是说不是取的font-size),再得出 line-box 的高度(具体来说就是从子元素的最高点到最低点的高度),所以默认情况下,一个 line-box 总是有足够的高度来容纳它的子元素。

    每个 HTML 元素实际上都是由多个 line-box 的容器,如果你知道每个 line-box 的高度,那么你就知道了整个元素的高度。

  • content area (内容区) 内容区是围绕着文字的一种box,无法显示出来,其高度是由字体度量定义的,取决于font-size和字体度量为其添加的padding(注意,此padding非css中的padding,详情参考这篇IFC相关的译文)。

  • containing box (包含盒子)包含盒子是由一个一个行框盒子组成的,包裹着行框盒子。

图片描述

原谅我画图水平有限,不过仔细辨认还是能看出来的~ _

取值

一般情况下,浏览器默认的line-height为1.2。可以自定义 line-height 覆盖这个初始值,那么该怎样设置line-height呢?有以下5种方式:

描述
normal默认。设置合理的行间距。
number设置数字,此数字会与当前的字体尺寸相乘来设置行间距,即number为当前font-size的倍数。
length设置固定的行间距。
%基于当前字体尺寸的百分比行间距。
inherit规定应该从父元素继承 line-height 属性的值。

看起来如此简单~但是,line-height是个可继承属性,它的继承规则有那么一点点复杂……

继承

需要提前说明的是:line-height的大小与font-size息息相关,除了指定line-height为多少px,剩下的设置方式都是基于font-size算出来的。 下面逐个讲一讲~

  • inherit 这个其实没什么说的,继承父元素line-height的值,所以父元素的是多少就是多少。 如果其后代元素不设置line-height 的话,也会是这个值。

  • length 假设设置 line-height 为20px,那么该行的该行的行高就是20px,与 font-size 无关,不会随着 font-size 做相应比例的缩放。 这个长度值(20px)会被后代元素继承,所有的后代元素会使用这个相同的、继承的 line-height (20px),除非后代元素设定 line-height 。

  • 百分比 假设自身的 font-size 为16px,line-height 设为120%。那么其行高为:16 * 120% = 19.2px。即 line-height 是根据自身的 font-size 计算出来的。 子元素会继承父元素的line-height,那么它继承的是什么呢,百分比(120%)?还是19.2px? 答案是后者,19.2px,即父元素line-height计算后的最终值。

  • normal line-height 设置为 normal 的时候,行高取决于浏览器的解析,一般是1.2。 与前面不同的是,line-height 设置为 normal 的元素,其子元素不再继承其line-height计算后的最终值,而是根据子元素自身的 font-size 进行计算。见下表~

    elementfont-sizeline-height计算后的lline-height
    body16pxnormal16px * 1.2 = 19.2px
    h132pxnormal32px * 1.2 = 38.4px

    可见,子元素随着自身 font-size 的大小而做相应比例的缩放。

  • 纯数字 如果既想要 normal 的灵活,又想设置一个自定义的值,那就要用 纯数字 啦~ 纯数字方式与 normal 唯一的不同,就是数值的大小,纯数字可以自己随意设定,而 normal 的值是浏览器决定的。

    elementfont-sizeline-height计算后的lline-height
    body16px1.516px * 1.5 = 24px
    h132px1.532px * 1.5 = 48px

    其后代元素会继承这个数值(比如 1.5),然后根据自身的 font-size 算出自身的line-height。

总结如下:

设置方式line-height计算后的line-height子元素继承的line-height
inherit父元素的line-height值不用计算父元素的line-height值
length20px不用计算20px
%120%自身font-size (16px) * 120% = 19.2px继承父元素计算后的line-height值 19.2px,而不是120%
normal1.2自身font-size (16px) * 1.2 = 19.2px继承1.2,line-height = 自身font-size(32px) * 1.2 = 38.4px
纯数字1.5自身font-size (16px) * 1.2 = 19.2px继承1.5,line-height = 自身font-size(32px) * 1.5 = 48px

那么,哪一种是最好的方式呢? 一般来数,设置行高的值为 纯数字 是最推荐的方式,因为其会随着对应的 font-size 而缩放。


这是对line-height的一点总结,欢迎小伙伴们拍砖哈~

参考

MDN line-height

深入了解css的行高Line Height属性

CSS行高——line-height

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值