我有一div组display:block(90px height和width),里面有一些文字。
div
display:block
90px
height
width
我需要将文本垂直和水平对齐在中心。
我试过text-align:center了,但它没有做垂直居中部分,所以我试过vertical-align:middle了,但没有用。
text-align:center
vertical-align:middle
有任何想法吗?
如果它是一行文本和/或图像,那么很容易做到。只需使用:
text-align: center; vertical-align: middle; line-height: 90px; /* The same as your div height */
而已。如果它可以是多行,那么它会更复杂一些。但是http://pmob.co.uk/上有解决方案 。寻找“垂直对齐”。
由于它们往往是黑客或添加复杂的 div… 我通常使用一个带有单个单元格的表格来完成它… 使其尽可能简单。
除非您需要让它在 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 项目中删除该行,它就会自动收缩包装。
flex: ...
示例:http: //jsfiddle.net/2woqsef1/2/
上面的示例已经在包括 MS Edge 和 Internet Explorer 11 在内的主要浏览器上进行了测试。
如果您需要对其进行自定义,请提供一个技术说明:在 flex 项目内部,由于此 flex 项目本身不是 flex 容器,因此旧的非 flexbox 方式的 CSS 可以按预期工作。然而,如果你在当前的 flex 容器中添加一个额外的 flex 项,这两个 flex 项将被水平放置。要使它们垂直放置,请将 添加flex-direction: column;到 flex 容器中。这就是它在 flex 容器及其 直接 子元素之间的工作方式。
flex-direction: column;
还有另一种居中的方法:不指定centerflex 容器在主轴和交叉轴上的分布,而是指定margin: autoflex 项目以占用所有四个方向上的所有额外空间,以及均匀分布的边距将使弹性项目在各个方向居中。这有效,除非有多个弹性项目。此外,此技术适用于 MS Edge,但不适用于 Internet Explorer 11。
center
margin: auto
它可以更常用地完成transform,即使在 Internet Explorer 10 和 Internet Explorer 11 等较旧的浏览器中也能正常工作。它可以支持多行文本:
transform
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 会完成这项工作。
line- height