博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vertical-align:middle的居中细节调整
阅读量:5753 次
发布时间:2019-06-18

本文共 1014 字,大约阅读时间需要 3 分钟。

使用vertical-align:middle可以让行级元素垂直居中,但这个居中是以文字的中线来计算的,而文字的中线在不同的字体上不同,甚至相同的字体在不同的浏览器上显示的都不同。所以直接使用vertical-align:middle很难完美居中,因此需要其它调整。

运行<!DOCTYPE html>
<style>
div {
  border
:1px solid red;
  width
:200px;
  height
:100px;
  line-height
:100px;
  text-align
:center;
}
span {
vertical-align:middle;}
#box {
  display
:inline-block;
  width
:100px;
  height
:98px;
  background
:#EEE;
}
</style>
<div>
  abc<span id="box"></span>def
</div>
  当容器内存在vertical-align:middle元素时,它们的中线会被对其到所在行的基线上。而所在行的基线未必是中线,基线与中线偏离的距离就是vertical-align:middle垂直居中时候出现的偏离距离。
  基线与中线的位置差异会受到字体、字形、字号,等影响。而且在不同浏览器上字体的渲染还存在差异,这样就不容易计算具体的偏差。但我们可以取消掉基线和中线的位置差,做法是将字号改到0,也就是不在行中直接使用文本节点。
运行<!DOCTYPE html>
<style>
div {
  border
:1px solid red;
  width
:200px;
  height
:100px;
  line-height
:100px;
  text-align
:center;
  font-size
:0px;
}
span {
  vertical-align
:middle;
  display
:inline-block;
  font-size
:1rem;
}
#box {
  width
:100px;
  height
:98px;
  background
:#EEE;
}
</style>
<div>
  <span>abc</span><span id="box"></span><span>def</span>
</div>

转载于:https://www.cnblogs.com/axl234/p/3907262.html

你可能感兴趣的文章
Windows 10 技术预览
查看>>
Tomcat http跳转https
查看>>
一个自动布署.net网站的bat批处理实例
查看>>
tomcat 安装
查看>>
AIX:物理卷及有关概念
查看>>
我的友情链接
查看>>
Centos6.6安装选包及基础场景说明
查看>>
java基础面试题-1
查看>>
深克隆与序列化效率的比较
查看>>
lamp+nginx代理+discuz+wordpress+phpmyadmin搭建一
查看>>
nagios监控使用139邮箱报警
查看>>
Windows Phone 7 中各种Task解说(启动器与选择器)
查看>>
罗森伯格助力2011年中国智能建筑技术发展应用论坛哈尔滨站
查看>>
网络割接
查看>>
windows server 2016 活动目录(二)
查看>>
openstack G版 修改vm的flavor级别
查看>>
python_控制台输出带颜色的文字方法
查看>>
java泛型中特殊符号的含义
查看>>
一秒 解决 ERROR 1044 (42000): Access denied for user ''@'localhost' to database 'mysql 问题
查看>>
Android组件化最佳实践 ARetrofit原理
查看>>