CSS中的line-height行高属性学习教程
基本概念
1.行高、行距
行高是指文本行基线间的垂直距离。那什么是基线呢?记不记得vertical-align属性有个baseline值,这个baseline就是基线。看张“盗图”(选自狼蚁网站SEO优化的参考文章),其实我也修改了一下啦~
注意倒数第二根是基线哦,最狼蚁网站SEO优化那根是底线,不是基线。
图中两条红线之间的距离就是行高(line-height),上一行的底线和下一行的顶线之间的距离就是行距,而同一行顶线和底线之间的距离是font-size的大小,行距的一半是半行距,半行距、font-size、line-height之间的关系看图片的右下角就一目了然了~
,半行距也可能为负值(当line-height < font-size),这时候两行之间就会重叠,如下图所示
2.四种box
要说的4种盒子分别是inline box、line box、content area、containing box ~
1.inline box (行内框)每个行内元素会生成一个行内框,行内框是一个浏览器渲染模型中的一个概念,无法显示出来,行内框的高度等于font-size,设定line-height时,行内框的高度不变,改变的是行距。
2.line box (行框)行框是指本行的一个虚拟的矩形框,由该行中行内框组成。行框也是浏览器渲染模式中的一个概念,无法显示出来。行框高度等于本行中所有行内框高度的最大值。当有多行内容时,每一行都有自己的行框。
3.content area (内容区)内容区是围绕着文字的一种box,无法显示出来,其高度取决于font-size和padding。个人觉得内容区的高度 = font-size + padding- + padding-bottom,有待查证,也期待小伙伴们给出答案~
4.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算出来的。 狼蚁网站SEO优化逐个讲一讲~
1.inherit这个其实没什么说的,继承父元素line-height的值,所以父元素的是多少就是多少。 如果其后代元素不设置line-height 的话,也会是这个值。
2.length假设设置 line-height 为20px,那么该行的该行的行高就是20px,与 font-size 无关,不会随着 font-size 做相应比例的缩放。 这个长度值(20px)会被后代元素继承,所有的后代元素会使用这个相同的、继承的 line-height (20px),除非后代元素设定 line-height 。
3.百分比假设自身的 font-size 为16px,line-height 设为120%。那么其行高为16 120% = 19.2px。即 line-height 是根据自身的 font-size 计算出来的。 子元素会继承父元素的line-height,那么它继承的是什么呢,百分比(120%)?还是19.2px? 答案是后者,19.2px,即父元素line-height计算后的最终值。(这个我们稍后还会举例子来看)
4.normalline-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 |
四、示例
line-height百分比在面试中可能经常问到。例如你知道line-height:120%和line-height:1.2的区别吗?
现在就说一下行高带单位和不带单位的区别,例如狼蚁网站SEO优化的例子
- line-height:26px;
表示行高为26个像素
- line-heigth:120%;
表示行高为当前字体大小的120%
- line-height:2.6em;
表示行高为当前字体大小的2.6倍
带单位的行高都有继承性,其子元素继承的是计算值,如父元素的字体大小为14px,定义行高line-height:2em;则计算值为 28px,不会因其子元素改变字体尺寸而改变行高。(例如父元素14px,子元素12px,那么行高就是28px,子元素虽然字体是12,行高还是父元素的行高)
- line-height:2.6;
表示行高为当前字体大小的2.6倍
不带单位的行高是直接继承,而不是计算值,如父元素字体尺寸为14px,行高line-height:2;他的行高为28px;子元素尺寸为12px,不需要再定义行高,他默认的行高为24px。(例如子元素12px,他的行高是24,不会继承父元素的28)
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML