css中line-height与height的学习总结

深入了解line-height和height有助于我们在实践中灵活进行设计。所以让我们赶紧开始把。

注:

斜体加粗:在基本术语中有补充

文章中框模型(盒模型)是一回事

问题引入

height与line-height是什么?

       height:height 属性设置元素的高度。行内非替换元素会忽略这个属性。

       line-height:设置行高。所有元素都可以使用。总结部分有对它的总结

height与line-height的作用对象是什么?

       height:块级元素本身内容框。

line-height:块级元素内的匿名文本行内元素行内框。它首先会影响行间距,改变行内框的高度,进而间接影响行框的高度。

height与line-height之间存在什么关系?

       两者之间并没有直接关系,只是因为大小的不同而产生视觉上的效果。

必要基本术语和概念

在深入理解之前先来补充一些别要的概念才能帮助我们更好的去理解一个东西。

名词

匿名文本:指所有未包含在行内元素中的字符串。如下图1

em框:font-size确定em框的高度,但字形可能比em框还高。见图2

内容区:内容区存在两种,1、内容区可以是元素中各个字符的em框串在一起的构成的框。 2、由元素中字符字形描述的框。最终的内容区的是什么样子取决于用户代理的选择(虽然两者 的高度不尽相同,但是对于后面的操作确实一样。小声说一句谷歌浏览器就是第二种)见图三

行间距:是font-size和line-height的差值。这个实际上要分为两半,分别应用到内容区的顶部和底部。为内容区增加的着两部分称为半间距。行间距只应用于非替换元素。另外行间距不会出现合并(如外边距)现象。见图三

行内框:这个框通过向内容区增加行间距来描述。对于非替换元素,元素的行内框高度刚好等于line-height的值。对于替换元素,元素行内框的高度则恰好等于内容区的高度。因为上一条的原因。见图三

行框:这是包含该行中出现的行内框的最高点和最低点的最小框。换句话说,行框的上边界要位于最高行框的上边界,而行框的底边要放在最低行内框的下边界。见图四

图1​
图2
图三
图四

概念

内容区类似于一个块级元素的内容框

行内元素的背景应用于内容区及所有内边距

行内元素的边框要包围内容区及所有内边距(和边框)。

非替换元素的内边距、边框和外边距对行内元素或其他生成的框没有垂直效果;也就是说,他们不会影响元素行内框的高度(也不会影响包含该元素行框的高度)。

替换元素的外边距和边框确实会影响该元素行内框的高度,相应地,也可能影响包含该元素的行框的高度

字体

左边的line-height可以忽略,重要的是右边的。具体文章看真正的能理解CSS中的line-height,height与line-height

作用的过程

要深入了解,必须要知道它们作用的详细的过程

height的作用过程

对于所有块级元素都可以设定它们内容框的高度,但要注意只允许为非负值。

line-height的作用过程

确定各行内的行内元素或匿名文本的行内框高度

主要计算分为两部分,一部分是根据内容区的高度(这里用户代理决定最终值,如果以em框合并的方式则高度为font- size,见上面),另一部分则是通过line-height-font-size=行间距,半间距分别加到内容区的顶端和底端。最终内容区的高度就是:行间距+内容区高度

2.确定基线的位置并对齐

这个过程一般是由浏览器处理完成,确定各个元素和匿名文本的基线位置,以及行的基线,并将各个元素或者匿名文本放到行的基线上。另外内容区需要确定它

3.对指定vertical-algin的元素的行内框进行偏移。(本文未涉及)

详细见vertical-algin的说明

4.确定行框的高度(以上都是对行内元素的影响过程)

由上面对行框的定义,可以简单的说,行框的高度等于:最高的行内框的顶端到基线的距离+最低行内框的底端到基线的距离。

5.行框效果的叠加(这也是对块级元素影响的过程)

一条规则:行框都是紧紧排列的,各行框的顶端挨着上一行行框的底端

总结

好多文章中都指出,在不设定height的情况下,元素的高度由line-height决定,根据上面的内容我们可以更加详细的解释,默认情况下,块级元素的高度由其内容的高度来决定也就是height:auto;。行框也属于一种”块级“元素,它当中包含了许多匿名文本和行内元素,并且由它们决定自身高度,这样行框的高度就会把元素高度height撑起来。看一下图理解的更快。

line-height:尽管所有的元素都具有该属性,但实际上,只直接影响行内元素和其他行内内容而不直接影响块级元素,也就是说可以为一个块级元素设置line-height值,但是这个值只应用到块级元素的内联内容才会有视觉效果。(line-height具有继承性)。

紫色:块级元素的内容框

黑色:行框

蓝色:内容区

红色:半间距

橙色:基线

注:原谅我。。我真的不会画画。。

然后我们就可以想一下为什么line-height与height指不同带来垂直方向上的显示情况?

例如:height<line-height,行框的高度大于元素(内容框)的高度,也就是说元素盛不下行框,行框的一部分被“遮挡住”。自然而然,显示上就会在元素垂直中线以下了。

其余两种情况可以自己试试。不过似乎应该,我们经常用到的是相等的情况。

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