详解CSS行高line-height属性

详解CSS行高line-height属性

(推荐教程:CSS视频教程)

初入前端的时候觉得CSS知道display、position、float就可以在布局上游刃有余了,随着以后工作问题层出不穷,才逐渐了解到CSS并不是几个style属性那么简单,最近看了一些关于行高的知识,就此总结一下。

所谓行高是指文本行基线间的垂直距离。要想理解这句话首先得了解几个基本知识:

顶线、中线、基线、底线

            Test                    span            {                padding:0px;                line-height:1.5;            }                        
中文English English中文

登录后复制

wps_clip_image-14492

立即学习“前端免费学习笔记(深入)”;

从上到下四条线分别是顶线、中线、基线、底线,很像才学英语字母时的四线三格,我们知道vertical-align属性中有top、middle、baseline、bottom,就是和这四条线相关。

尤其记得基线不是最下面的线,最下面的是底线。

行高、行距与半行距

行高是指上下文本行的基线间的垂直距离,即图中两条红线间垂直距离。

行距是指一行底线到下一行顶线的垂直距离,即第一行粉线和第二行绿线间的垂直距离。

半行距是行距的一半,即区域3垂直距离/2,区域1,2,3,4的距离之和为行高,而区域1,2,4距离之和为字体size,所以半行距也可以这么算:(行高-字体size)/2

wps_clip_image-14662

内容区、行内框、行框

内容区:底线和顶线包裹的区域,即下图深灰色背景区域。

wps_clip_image-14718

行内框,每个行内元素会生成一个行内框,行内框是一个浏览器渲染模型中的一个概念,无法显示出来,在没有其他因素影响的时候(padding等),行内框等于内容区域,而设定行高时行内框高度不变,半行距【(行高-字体size)/2】分别增加/减少到内容区域的上下两边(深蓝色区域)

行框(line box),行框是指本行的一个虚拟的矩形框,是浏览器渲染模式中的一个概念,并没有实际显示。行框高度等于本行内所有元素中行内框最大的值(以行高值最大的行内框为基准,其他行内框采用自己的对齐方式向基准对齐,最终计算行框的高度),当有多行内容时,每行都会有自己的行框。

中文English 中文English English中文 English中文

登录后复制

wps_clip_image-14832

line-height

基本概念搞明白了我们就可以说说本文的主角line-height属性了。

定义:line-height 属性设置行间的距离(行高),不能使用负值。该属性会影响行框的布局。在应用到一个块级元素时,它定义了该元素中基线之间的最小距离而不是最大距离。line-height 与 font-size 的计算值之差(行距)分为两半,分别加到一个文本行内容的顶部和底部。可以包含这些内容的最小框就是行框。

可能的值

值说明normal默认,设置合理的行间距。number设置数字,此数字会与当前的字体尺寸相乘来设置行间距。相当于倍数length设置固定的行间距。%基于当前字体尺寸的百分比行间距。inherit规定应该从父元素继承 line-height 属性的值。

貌似很简单,但感觉没什么用出的样子,那就让我们看看line-height的几个应用

div文字垂直居中

div居中对齐一直是个难题,水平还好解决些,margin:0 auto; 可以解决现代浏览器,IE下text-align:center。但垂直居中就没那么简单了,默认是这样子的。

This is a test.
This is a test.

登录后复制

wps_clip_image-14888

我们可以利用line-block这样做

This is a test.
This is a test.

登录后复制

wps_clip_image-14910

单行就比较简单了,把line-height设置为box的大小可以实现单行文字的垂直居中

This is a test.

登录后复制

wps_clip_image-14956

元素对行高影响

行框高度是行内最高的行内框高度,通过line-height调整,内容区行高与字体尺寸有关,padding不对行高造成影响。

This is a test
This is a test

登录后复制

wps_clip_image-15002

第二个span虽然因为padding原因内容区变大,当行高并未改变

行高的继承

行高是可继承的,但并不是简单的copy父元素行高,继承的是计算得来的值。

1232
123

登录后复制

按一般理解既然line-height可以继承,那么p元素的行高也是150%了,可是事实是这样的

wps_clip_image-15035

非但没有变成150%,反而连100%都没有,重叠了!这就是继承计算的结果,如果父元素的line-height有单位(px、%),那么继承的值则是换算后的一个具体的px级别的值;上例p得到的是10px*150%=15px的行高,而P的字体大小为30px,所以发生了重叠。

而如果属性值没有单位,则浏览器会直接继承这个“因子(数值)”,而非计算后的具体值,此时它的line-height会根据本身的font-size值重新计算得到新的line-height 值。

1232
123

登录后复制

wps_clip_image-15080

所以在使用line-height时,除非你刻意否则尽量使用倍数设值

更多编程相关知识,请访问:CSS视频教程!!

以上就是详解CSS行高line-height属性的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2884164.html

(0)
上一篇 2025年3月10日 20:25:48
下一篇 2025年3月8日 10:22:50

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • css怎么给一个盒子加盒阴影

    css给一个盒子加盒阴影的方法:可以利用box-shadow属性来添加盒阴影,如【box-shadow: 10px 10px 5px #888888;】。box-shadow属性可以设置一个或多个下拉阴影的框。 box-shadow属性可以…

    2025年3月10日
    200
  • css如何实现文字不能选中

    css实现文字不能选中的方法:可以利用user-select属性来实现,如【-webkit-user-select:none;-moz-user-select:none;】。user-select属性用来控制内容的可选择性。 属性介绍: u…

    2025年3月10日
    200
  • css中grid布局和表格有什么区别

    css中grid布局和表格的区别是:1、grid是在css中实现的,表格是在html中实现的;2、grid是固定大小的,表格是大小可变的;3、grid继承自面板元素,表格继承自块元素。 网格布局(Grid)是最强大的 CSS 布局方案。 它…

    2025年3月10日
    200
  • css里的display属性有啥作用

    css里的display属性的作用是规定元素应该生成的框的类型。display属性是前端开发中常用的一个属性,常用的属性值有block、none、inline、inline-block。 网页上的每个元素都是一个矩形框。display 属性…

    2025年3月10日
    200
  • css如何实现不显示table的边框

    css实现不显示table的边框的方法:可以利用border属性来实现,如【border:0;】。border属性用于设置所有的边框属性,如border-width,规定边框的宽度。 border 简写属性在一个声明设置所有的边框属性。 (…

    2025年3月10日
    200
  • css怎么控制字体大小

    在css中可以通过属性font-size控制字体大小,其属性值可以是任意的数字大小加px单位,该属性的使用语法如“h1 {font-size:250%;}”。 推荐:《css视频教程》 首先是关于字体大小的设置,用到的CSS属性是font-…

    2025年3月10日
    200
  • 怎么用css设置图片大小

    用css设置图片大小的方法:首先新建一个html文件;然后使用div标签创建一个模块,并在div标签内使用img标签创建一张图片;最后在img标签内使用style来设置图片宽度和高度属性即可。 推荐:《css视频教程》 新建一个html文件…

    2025年3月10日 编程技术
    200
  • css :first-child的作用是什么?

    在css中,:first-child选择器的作用为:匹配其父元素中的第一个子元素,语法“E:first-child{css代码}”;该选择器需要同时满足两个条件才起作用,一个是“第一个子元素”,另一个是“这个子元素刚好是E”。 在css中,…

    2025年3月10日 编程技术
    200
  • css怎么设置背景图片的透明度

    css设置背景图片的透明度的方法:可以利用opacity属性来进行设置,如【opacity: value|inherit;】。value规定不透明度,inherit规定从父元素继承opacity属性的值。 属性介绍: opacity 属性设…

    2025年3月10日
    200
  • css中的流体布局是什么

    css中的流体布局是指当网页缩小或放大时,网页布局会随着浏览器的大小而改变。流体布局的优势是如果用户的窗口很小,页面就会收缩以适应窗口,而不必横向滚动。 流体布局: 简单来说就是网页缩小和放大时网页布局会随着浏览器的大小而改变! (学习视频…

    2025年3月10日
    200

发表回复

登录后才能评论