Why does margin: auto only work horizontally and not vertically?(为什么自动边距只适用于水平方向,而不适用于垂直方向?)
问题描述
我看到,在开发网站时,在任意高度的容器中垂直居中放置(固定高度的)容器对Web开发人员(至少是我来说)来说总是一场噩梦,而在水平居中放置随机宽度的容器(固定宽度)时,margin:0px auto;在标准模型中往往是一种简单的解决方案。
当事情可以这么简单时,当涉及到将固定高度的容器居中放置在任意高度的容器中时,margin:auto 0px;为什么不适用于margin:auto 0px;?这样做有什么特别的原因吗?
推荐答案
这真的没有你想象的那么可怕,只是不要使用边距。vertical-align是您真正应该依靠的流体高度垂直居中。我拼凑了一个快速演示来证明我的观点:
* {
margin: 0;
padding: 0;
}
html,
body {
height: 100%;
text-align: center;
}
span {
height: 100%;
vertical-align: middle;
display: inline-block;
}
#any-height {
background: #000;
text-align: left;
width: 200px;
height: 200px;
vertical-align: middle;
display: inline-block;
}
<span></span>
<div id="any-height"></div>
参见:http://jsfiddle.net/Wexcode/jLXMS/
这篇关于为什么自动边距只适用于水平方向,而不适用于垂直方向?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么自动边距只适用于水平方向,而不适用于垂直方向?
基础教程推荐
- 带角度的选项卡:仅使用 $http 在单击时加载选项卡 2022-01-01
- HTML5 画布调整为父级 2022-01-01
- 最佳动态 JavaScript/JQuery 网格 2022-01-01
- CORS:当凭据标志为真时,无法在 Access-Control-Allow-Origin 中使用通配符 2022-01-01
- 当木偶师打开Chrome时,不能使用Chrome扩展 2022-01-01
- 逻辑运算符 ||在 javascript 中,0 代表 Boolean false? 2022-01-01
- 从快速中间件中排除路由 2022-01-01
- 使用 jQuery 在悬停时交换 DIV 类 2022-01-01
- 在 Javascript 中使用 Fetch API 上传文件并显示进度 2022-01-01
- 即使每次插入第一个输入的值不同,第二个输入仍显示相同的输入值 2022-01-01
