gpt4 book ai didi

html - 如何在 div block 内将文本(水平和垂直)居中?

转载 作者:行者123 更新时间:2023-11-28 07:30:19 28 4
gpt4 key购买 nike

我有一个 div 设置为 display:block (90px heightwidth),里面有一些文字。

我需要文本在垂直和水平方向上居中对齐。

我试过 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/上有解决办法.寻找“垂直对齐”。

因为它们往往是 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 容器,因此 CSS 的旧非 flex 盒方式可以按预期工作。但是,如果你向当前的 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 就可以完成这项工作。

关于html - 如何在 div block 内将文本(水平和垂直)居中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31551298/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com