如果是一行文本和/或图像,那么很容易做到。只需使用:
text-align: center;
vertical-align: middle;
line-height: 90px; /* The same as your div height */
就是这样。如果它可以是多行,那么它会更复杂一些。但是http://pmob.co.uk/上有解决方案.寻找“垂直对齐”。
由于它们往往是 hack 或添加复杂的 div...我通常使用带有单个单元格的表格来执行此操作...以使其尽可能简单。
2020 年更新:
除非您需要使其在 Internet Explorer 10 等早期浏览器上运行,否则您可以使用 flexbox。是widely supported by all current major browsers .基本上,需要将容器指定为 flex 容器,并沿其主轴和交叉轴居中:
#container {
display: flex;
justify-content: center;
align-items: center;
}
为 child 指定一个固定的宽度,称为“flex 元素”:
#content {
flex: 0 0 120px;
}
示例:http://jsfiddle.net/2woqsef1/1/
要收缩包装内容,更简单:只需从 flex 元素中删除 flex: ...
行,它就会自动收缩包装。
示例:http://jsfiddle.net/2woqsef1/2/
以上示例已经在包括 MS Edge 和 Internet Explorer 11 在内的主流浏览器上进行了测试。
如果您需要对其进行自定义,请提供一个技术说明:在 flex 项内部,由于该 flex 项本身不是 flex 容器,旧的非 flexbox 方式的 CSS 可以按预期工作。然而,如果你在当前的 flex 容器中添加一个额外的 flex 项,这两个 flex 项将被水平放置。要使它们垂直放置,请将 flex-direction: column;
添加到 flex 容器中。这就是它在 flex 容器和它的 立即 子元素之间的工作方式。
还有另一种居中方法:不指定 center
为 flex 容器的主轴和交叉轴上的分布,而是指定 margin: auto
在 flex 元素上占据所有四个方向上的所有额外空间,并且均匀分布的边距将使 flex 元素在所有方向上居中。这有效,除非有多个 flex 元素。此外,此技术适用于 MS Edge,但不适用于 Internet Explorer 11。
2016/2017 年更新:
通常可以使用 transform
来完成,即使在 Internet Explorer 10 和 Internet Explorer 11 等旧版浏览器中也能正常工作。它可以支持多行文本:
position: relative;
top: 50%;
transform: translateY(-50%);
示例:https://jsfiddle.net/wb8u02kL/1/
收缩包装宽度:
上述解决方案为内容区域使用了固定宽度。要使用收缩包装的宽度,请使用
position: relative;
float: left;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
示例:https://jsfiddle.net/wb8u02kL/2/
如果需要对 Internet Explorer 10 的支持,则 flexbox 将不起作用,而上述方法和 line-height
方法将起作用。否则,flexbox 会完成这项工作。
我是一名优秀的程序员,十分优秀!