小编典典

如何在 div 块内居中文本(水平和垂直)?

all

我有一divdisplay:block90px heightwidth),里面有一些文字。

我需要将文本垂直和水平对齐在中心。

我试过text-align:center了,但它没有做垂直居中部分,所以我试过vertical-align:middle了,但没有用。

有任何想法吗?


阅读 117

收藏
2022-02-28

共1个答案

小编典典

如果它是一行文本和/或图像,那么很容易做到。只需使用:

text-align: center;
vertical-align: middle;
line-height: 90px;       /* The same as your div height */

而已。如果它可以是多行,那么它会更复杂一些。但是http://pmob.co.uk/上有解决方案
。寻找“垂直对齐”。

由于它们往往是黑客或添加复杂的 div… 我通常使用一个带有单个单元格的表格来完成它… 使其尽可能简单。


2020 年更新:

除非您需要让它在 Internet Explorer 10 等早期浏览器上运行,否则您可以使用
flexbox。目前所有主流浏览器都广泛支持它。基本上,需要将容器指定为 flex
容器,并沿其主轴和交叉轴居中:

#container {
  display: flex;
  justify-content: center;
  align-items: center;
}

为孩子指定一个固定的宽度,称为“弹性项目”:

#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 容器及其 直接 子元素之间的工作方式。

还有另一种居中的方法:不指定centerflex 容器在主轴和交叉轴上的分布,而是指定margin: autoflex
项目以占用所有四个方向上的所有额外空间,以及均匀分布的边距将使弹性项目在各个方向居中。这有效,除非有多个弹性项目。此外,此技术适用于 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 会完成这项工作。

2022-02-28