深入理解CSS中的line-height的使用

所属分类: 网页制作 / CSS 阅读数: 1730
收藏 0 赞 0 分享

什么是line-height(行高)?

line-height 是指两行文字基线之间的距离。

什么是基线?

基线、底线、顶线、中线

 

注意:

  • 基线(base line)并不是汉字文字的下端沿,而是英文字母“x”的下端沿。
  • 不同字体的基线不尽相同。

行距、行高

 

line-height 与行内框盒子模型

所有内联元素的样式表现都与行内框盒子模型有关。例如浮动的图文环绕效果... and so on

什么是行内框盒子模型

我们通过下面这段代码进行讲解

<p>这是一行普通的文字,这里有个<em>em</em>标签</p>

在这段代码中包含了 4 中盒子:

content area 内容区是指底线和顶线包裹的区域(行内元素 display:inline 可以通过 background-color 属性显示出来),实际中不一定看得到,但确实存在。内容区的大小依据 font-size 的值和字数进行变化。

inline boxes 。内联盒子不会让内容成块排列,而是排成一行。如果外部 inline 水平的标签( spanaem 等)则属于 内联盒子 ,如果是光秃秃的文字则属于 匿名内联盒子

line boxes 。每一行就是一个 行框盒子 。每个行框盒子又是由一个个 内联盒子 组成。

containing box 包含盒子。 包含盒子 是由一行一行的 行框盒子 组成。 <p> 标签就代表了一个 包含盒子 。(即上图中的绿色部分)

line-height 的高度机理

深入理解内联元素的高度表现

在讲解原理之前,我们先看以下代码:

<p>这是一行普通的文字,这里有个<em>em</em>标签</p>
console.log(document.querySelector('p').clientHeight); // 输出36px

现在我们思考这样几个问题:

  • 元素的高度从何而来?
  • 是由里面的文字撑开的?

the answer is :元素的高度是由 line-height 决定的:

line-height 明明是两基线之间的距离,单行文字哪来行高,还控制了高度?

  • 行高由于其继承性,影响无处不在,即使单行文本也不例外。
  • 高度的表现不是行高,而是内容区域和行间距。
  • 内容区域高度+行间距=行高
  • 内容区域高度只与字号以及字体有关,与 line-height 没有任何关系。(在 simsun 字体下,内容区域高度等于 font-size )。换句话说,在 simsun 字体下: font-size+行间距=line-height
  • 行间距是上下均分的。

总结

  • 行高决定内联盒子高度;行间距是墙头草,可大可小(甚至负值),保证高度正好等于行高。
  • 多行文本的高度等于单行文本的高度累加。

 line-height 的各类属性值

normal

line-height:normal; 默认属性值,与浏览器相关,且与元素字体相关联。

 <number>

line-height:1.5; 使用数值作为行高,根据当前元素的 font-size 大小计算。

 <length>

line-height:1.5em;line-height:1.5rem;line-height:20px; 使用具体单位作为行高值。

 <percent>

line-height:150% 使用百分比作为行高值。相对于设置了该 line-height 属性的元素的 font-size 大小计算。

 inherit

input{line-height:inherit;} ,行高继承。使用 inherit 可以让文本框样式可控性更强。 行高默认具有继承性,为什么还是这样做??? 控件元素 的默认行高是 normal ,而不是继承父级元素的行高。

line-height:1.5line-height:1.5em;line-height:150% 的区别

在计算结果上是相同的,但是所影响的元素有区别。

  • line-height:1.5 所有可继承元素会根据 font-size 重新计算行高。(也就是说其子元素都会根据自身的 font-size * 1.5 计算行高,每个子元素都要进行一次计算。)
  • line-height:150%/1.5em ,当前元素根据 font-size 计算行高,继承给下面的元素。(当前元素根据 font-size 计算行高,然后将所计算的出来的值继承给后代,也就是说只需要当前元素进行计算,而子元素不需要重新计算。)

body 全局数值使用经验

如果是 blog ,已阅读为主的网页, line-height:1.5/1.6 较为适宜。

如果是面向用户,并不是阅读为主的网页,则推荐使用匹配 20 像素的使用经验。 body{font-size:14px;line-height:1.4286} 或者合并形式 body{font:14px/1.4286 'microsoft yahei'}

line-height 与图片高度表现。

line-height 不会影响图片的高度。

隐匿文本节点: <p> 标签是一个文本节点,其默认会有文本。即使 <p></p> ,也就是当内容为空时,也存在文本节点,只不过看不到而已。这样的节点称其为隐匿文本节点,也正因为隐匿文本节点的存在,才会造成下面图中的情形。

 

 

如何消除图片与底部之间的间隙?

在项目开发中,我们偶尔会遇到以下情形:

 

解决的办法主要有以下三种:

1.图片块状化。( vertical-align )只适用于 inline``inline-block 元素,也就是说对于 block 元素并没有基线对齐的说辞。 img{display:block;}

2.图片底线对齐 img{vertical-align:bottom;}

3.行高足够小,使基线上移。 .box{line-height:0}

line-height的实际应用

1.实现大小不固定的图片,多行文字的垂直居中

2.实现多行文本水平垂直居中

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

CSS伪类对象before和after的用法实例详解

这两个伪类对象只有在清楚浮动clearfix的时候会用到哈,最近在研究css3的时候觉得它两个的搭配不仅能够减少代码量并且能整出很巴适的效果
收藏 0 赞 0 分享

CSS3 实用技巧:实现黑白图像效果示例代码

本文为大家详细介绍下CSS3实现黑白图像效果的具体思路及代码,感兴趣的朋友可以看下截图,希望对大家有所帮助
收藏 0 赞 0 分享

IE.JS解决IE兼容性问题方法汇总

正如标题所言它修复了许多的HTML和CSS问题,并使得透明PNG在IE5、IE6下正确显示,下面为大家介绍下具体针对不同浏览器的调用方法,感兴趣的朋友可以参考下哈
收藏 0 赞 0 分享

实现CSS3中的border-radius(边框圆角)示例代码

本文为大家详细介绍下如何实现CSS3中的border-radius(圆角),具体代码如下,感兴趣的朋友可以参考下哈,希望对大家有所帮助
收藏 0 赞 0 分享

CSS line-height行高上下居中垂直居中样式属性

我们在css编写中需要对大篇幅的内容显示的更好看,有些间隔,不要在挤在一起难看,就可以使用Line-Height属性进行控制
收藏 0 赞 0 分享

CSS Float布局过程与老生常谈的三栏布局

这篇文章就是总结一下怎样使用CSS中的float属性进行布局,其实网上有很多讨论这个话题的文章了,但我觉得都没说到点子上。那就来老生常谈一次吧,CSS之Float布局
收藏 0 赞 0 分享

邮箱css加载失败怎么办 网站css加载异常原因分析

造成css加载失败的原因有很多,脚本之家也遇到过,这可能跟你代码出错,浏览器、路径、编码等等都是有关联的。所以在具体情况具体分析。下面看看具体的方案
收藏 0 赞 0 分享

CSS控制样式的三种方式(优先级对比验证)

大家都知道,CSS的中文名叫做层叠样式表,而CSS在控制样式的时候,有三种引入方式,这里简单介绍下CSS控制样式的三种方式
收藏 0 赞 0 分享

meta http-equiv="X-UA-Compatible" content="IE=7" 意思是将IE8用IE7进行渲染

X-UA-Compatible是针对ie8新加的一个设置,对于ie8之外的浏览器是不识别的,这个区别与content=
收藏 0 赞 0 分享

Discuz7.2 IE9兼容性写法 杜工完全修补方案

因为Discuz7.2在IE9浏览器中有一系列的问题,所有要在以后的开发中考虑到ie9浏览器的一些问题了,这里简单介绍下,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多