学习笔记: css中的line-height

基本概念

<h3>行高、行距</h3>
行高是指文本行基线间的垂直距离。那什么是基线呢?记不记得vertical-align
属性有个baseline
值,这个baseline
就是基线。看张“盗图”(选自下面的参考文章),其实我也修改了一下啦~

注意:倒数第二根是基线哦,最下面那根是底线,不是基线。
图中两条红线之间的距离就是行高(line-height),上一行的底线和下一行的顶线之间的距离就是行距,而同一行顶线和底线之间的距离是font-size的大小,行距的一半是半行距,半行距、font-size、line-height之间的关系看图片的右下角就一目了然了~
半行距 = (line-height - font-size)/2

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


4种box
要说的4种盒子分别是inline box
、line box
、content area
、containing box
~
inline box (行内框) 每个行内元素会生成一个行内框,行内框是一个浏览器渲染模型中的一个概念,无法显示出来,行内框的高度等于font-size
设定line-height
时,行内框的高度不变,改变的是行距

line box (行框) 行框是指本行的一个虚拟的矩形框,由该行中行内框组成。行框也是浏览器渲染模式中的一个概念,无法显示出来。行框高度等于本行中所有行内框高度的最大值。当有多行内容时,每一行都有自己的行框。

content area (内容区) 内容区是围绕着文字的一种box,无法显示出来,其高度取决于font-size
和padding
个人觉得:内容区的高度 = font-size + padding-top + padding-bottom,有待查证,也期待小伙伴们给出答案~

containing box containing box 是包裹着上述三种box的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 进行计算。见下表~
element
font-size
line-height
计算后的lline-height

body
16px
normal
16px * 1.2 = 19.2px

h1
32px
normal
32px * 1.2 = 38.4px

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

纯数字 如果既想要 normal 的灵活,又想设置一个自定义的值,那就要用 **纯数字
** 啦~ 纯数字方式与 normal 唯一的不同,就是数值的大小,纯数字可以自己随意设定,而 normal 的值是浏览器决定的。
element
font-size
line-height
计算后的lline-height

body
16px
1.5
16px * 1.5 = 24px

h1
32px
1.5
32px * 1.5 = 48px

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

总结如下:
设置方式
line-height
计算后的line-height
子元素继承的line-height

inherit
父元素的line-height值
不用计算
父元素的line-height值

length
20px
不用计算
20px

%
120%
自身font-size (16px) * 120% = 19.2px
继承父元素计算后的line-height值 19.2px,而不是120%

normal
1.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
的一点总结,原文转载:https://segmentfault.com/a/1190000003038583

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,727评论 1 92
  • 参考文章:深入了解CSS的line-height属性Vertical-Align: 你需要知道的所有事【译】Ver...
    若邪Y阅读 3,422评论 1 6
  • 1. line-height有什么作用? line-height指定一行的行高,使用后会使文本在上下居中。 lin...
    小木子2016阅读 355评论 0 0
  • 行高和行距 line-height 是用于定于行高的css属性。什么是行高? 从上图可以清楚看到,一行文本对应会有...
    亚历山大猫阅读 935评论 0 1
  • 乌云越来越浓,越来越低,中午的时候天已像晚上一样黑。 村里家家亮起的灯,但忽然灯又全灭了,有电线杆子被风刮断了。 ...
    空中的梨子阅读 323评论 6 7