css水平或者垂直居中的写法(深入理解CSS行高line-height与文本垂直居中的原理)
css水平或者垂直居中的写法
深入理解CSS行高line-height与文本垂直居中的原理前言
在CSS中,line-height 属性设置两段段文本之间的距离,也就是行高,如果我们把一段文本的line-height设置为父容器的高度就可以实现文本垂直居中了,比如下面的例子:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
li {
width: 300px;
height: 200px;
border: 1px solid red;
}
span {
line-height: 200px;
}
</style>
</head>
<body>
<li>
<span>文本垂直居中原理</span>
</li>
</body>
</html>
这样,span标签中的文字就相对于li垂直方向居中了,想要文本水平居中设置text-align:center即可。
那么,它怎么就垂直居中了?为了弄清楚它,下面我们先来看几个概念。
1. 行框
在浏览器中,会将给每一段文本生成一个行框,行框的高度就是行高。行框由上间距、文本高度、下间距组成,上间距的距离与下间距的距离是相等的。
默认情况下一行文本的行高分为:上间距,文本的高度,下间距,并且上间距是等于下间距的,所以文字默认在这一行中是垂直居中的。
2. 文本中的几条线
几条线与行高的关系图解:
文本的行高也可以看成是基线到基线的距离。
如果一段文本的高度为16px,如果给他设置line-height的高度为200,那么相当于,文本的上下间距的高度增加了,但是文本本身的高度依然是16是不变的,并且一直默认在行框中垂直居中,而上间距和下间距平分了200px的高度并且减去文本本身的高度。所以,容器被这一行文本占满,而本身文字在自己的一行中是垂直居中的,所以看起来就像是在容器中垂直居中。
3. Chrome浏览器的默认值
谷歌浏览器字体的默认大小是:16px,字体的最小值为:12px,默认行高为:18px;默认情况下如果没有给li设置高度,那么这个li的高度会比其中文本的大小大一点(这个大多少现在没有办法确定)
4. 行高的单位
px(像素)
设置起来是最直接的,同时也最方便的。
%(百分号)
如果line-height单位设置为%,那么将来在计算的时候,基数是当前标签中的文本的字体的大小。
如果是%,%之前的数据一定是整数 :150% ,200%
em
效果跟%是一样一样的。
注意:一行em的大小相当于是当前标签中的font-size的大小。
如果是em,em之前的数据一定是:1.2em ,1.5em ,2em
不带单位
如果不涉及到继承,那么带不带单位(em)都是一样的效果,但是如果涉及到继承的话,那么就有很大的区别了:
1、如果单位是em,那么将来在继承的时候,我们的浏览器会先将行高对应的具体的数值计算出来以后再继承。
2、如果没有单位,那么将来在继承的时候,我们的浏览器会先将line-height这个属性继承给子元素,再在子元素的font-size来计算。line-height: 1.5。
5.行高可以被继承
我们知道,CSS的三大特性是继承、层叠、优先级。line-height也是可以被继承的,如下面的示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.father {
/*line-height: 20px;*/
}
</style>
</head>
<body>
<li class="father">
<li class="children">丰趣海淘</li>
</li>
</body>
</html>
接着我们给li设置一个行高等于20px
.father {
line-height: 20px;
}
我们再来看看.children标签的的变化,.children标签的文字行高变成20px了
而且,不管我们给行高设置什么单位(px、%、em、不带单位)都可以被继承。
6. 行高计算的基数
如果行高的单位不是px,那么将来行高要进行计算:这个计算需要一个基数,这个基数是当前标签的字体大小,而不是浏览器默认字体大小。以上面的例子为例,我们并没有设置任何字体大小,此时我们把line-height设置为150%,那么文字的行高将变为24px(16px*1.5=24)。
li {
line-height: 150%;
}
此时我们在给li设置一个font-size等于20px:
li {
line-height: 150%;
font-size:20px;
}
那么文字行高将会变成30px,20px*1.5=30px;
总结
以上就是CSS行高(line-height)及文本垂直居中原理的全部内容,希望本文的内容对大家学习CSS能有所帮助,如果各位有什么疑问欢迎留言探讨,小编会尽快给大家回复的。
- css水平或者垂直居中的写法(深入理解CSS行高line-height与文本垂直居中的原理)
- height与line-height的关系(为什么你写的height:100%不起作用)
- css line-height(CSS中的line-height行高属性学习教程)
- line-height 百分比与数值的区别
- css行高line-height的用法
- 小米Watch S1评测 或许能成为小米冲击高端可穿戴设备的里程碑(小米WatchS1评测或许能成为小米冲击高端可穿戴设备的里程碑)
- 手机QQ与小米路由器在一起 明天揭晓,敬请期待(手机QQ与小米路由器在一起)
- 小米音乐与 QQ 音乐合作,便捷迁移会员(小米音乐与QQ音乐合作)
- 小米推出米兔儿童电话手表奥特曼版,799 元,支持微信 QQ(小米推出米兔儿童电话手表奥特曼版)
- 贾怀胤唱《白龙马》 炸场 了 没想到京剧还能这么玩(贾怀胤唱白龙马)
- 白龙马的改编学生版,快来看看(白龙马的改编学生版)
热门推荐
- mysqlshell日常运维脚本(监控MySQL主从状态的shell脚本)
- sqlserver数据回退(SQLServer数据库处于恢复挂起状态的解决办法)
- SqlServer GO命令循环使用实例代码(SqlServer GO命令循环使用实例代码)
- 用mysql语句写python学生管理系统(Python基于mysql实现学生管理系统)
- apache跳转配置(Apache 的 order deny allow 设置说明)
- VPS服务器常用性能测试脚本汇总(VPS服务器常用性能测试脚本汇总)
- docker容器镜像内容(Docker容器从镜像恢复代码的操作步骤)
- 织梦cms漏洞怎么解决(织梦cms、帝国cms、PHPcms优缺点解析)
- pythonselenium隐藏浏览器窗口(Python Selenium 之关闭窗口close与quit的方法)
- C# xml和对象的序列化与反序列化