时间:2021-05-08
什么是line-height(行高)?
line-height 是指两行文字基线之间的距离。
什么是基线?
基线、底线、顶线、中线
注意:
行距、行高
line-height 与行内框盒子模型
所有内联元素的样式表现都与行内框盒子模型有关。例如浮动的图文环绕效果... and so on
什么是行内框盒子模型
我们通过下面这段代码进行讲解
<p>这是一行普通的文字,这里有个<em>em</em>标签</p>在这段代码中包含了 4 中盒子:
content area 内容区是指底线和顶线包裹的区域(行内元素 display:inline 可以通过 background-color 属性显示出来),实际中不一定看得到,但确实存在。内容区的大小依据 font-size 的值和字数进行变化。
inline boxes 。内联盒子不会让内容成块排列,而是排成一行。如果外部 inline 水平的标签( span 、 a 、 em 等)则属于 内联盒子 ,如果是光秃秃的文字则属于 匿名内联盒子 。
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 的各类属性值
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.5 、 line-height:1.5em; 、 line-height:150% 的区别
在计算结果上是相同的,但是所影响的元素有区别。
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.实现多行文本水平垂直居中
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
css设置行间距 css提供了一个设置行间距的line-height属性,可以通过line-height设置每行文字的距离。 语法:line-height:
要加上line-height,并且加上CSS代码:复制代码代码如下:#div-a{height:60px;line-height:60px;}XHTML代码:复
使用line-height垂直居中line-height:24px;使用固定宽度的容器并且需要一行垂直居中时,使用line-height即可(高度与父层容器一致
常常使用line-height设置内容(图片、文字)行高上下居中样式效果。一、line-height行高语法复制代码代码如下:line-height:22px.
前言在CSS中,line-height属性设置两段段文本之间的距离,也就是行高,如果我们把一段文本的line-height设置为父容器的高度就可以实现文本垂直居