我如何在CSS网格项目中垂直和水平的水平中心文本?

发布于 2025-02-03 08:20:03 字数 1007 浏览 2 评论 0原文

奇怪的是,CSS网格没有可以轻松执行此操作的属性(我的Codepen: htttps:htttps:// codepen.io/chiz/pen/dydezpz )。

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  grid-gap: 20px;
  align-items: center;
  justify-content: center;
}

.container div {
  background-color: gray;
  height: 100px;
}
<div class="container">
  <div>Box 1</div>
  <div>Box 2</div>
  <div>Box 3</div>
  <div>Box 4</div>
</div>

如果我使用align-felt:中心合理:中心 内部.container div part,它会缩小盒子的尺寸到内容的大小。

CSS网格是否应该具有诸如Grid-Item-Align之类的属性:顶级中心的东西? 我试图不使用90年代的CSS hacks来执行这种cos',这将破坏CSS网格的目的。

使用Flexbox,将我想要的东西对齐要容易得多。

It's strange that CSS grid doesn't have properties that can do this easily (my codepen here: https://codepen.io/Chiz/pen/dydeZpz).

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  grid-gap: 20px;
  align-items: center;
  justify-content: center;
}

.container div {
  background-color: gray;
  height: 100px;
}
<div class="container">
  <div>Box 1</div>
  <div>Box 2</div>
  <div>Box 3</div>
  <div>Box 4</div>
</div>

If I use align-self: center and justify-self: center inside the .container div part, it shrinks the sizes of the boxes down to the size of the content.

Shouldn't CSS grid have properties such as grid-item-align:top center sort of thing?
I'm trying not to use 90s CSS hacks to do this cos' that would defeat the purpose of CSS grid.

With flexbox, it's far easier to align things where I want.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

一指流沙 2025-02-10 08:20:03

Flex网格一起工作。只需在所需的项目上应用您的flex - 位置属性即可。

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  grid-gap: 20px;
  align-items: center;
  justify-content: center;
}

.container div {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: gray;
  height: 100px;
}
<div class="container">
  <div>Box 1</div>
  <div>Box 2</div>
  <div>Box 3</div>
  <div>Box 4</div>
</div>

flex and grid works wonderfully together. Just apply your flex-positioning properties on the item you want.

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  grid-gap: 20px;
  align-items: center;
  justify-content: center;
}

.container div {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: gray;
  height: 100px;
}
<div class="container">
  <div>Box 1</div>
  <div>Box 2</div>
  <div>Box 3</div>
  <div>Box 4</div>
</div>

再可℃爱ぅ一点好了 2025-02-10 08:20:03

在容器上使用网格时,您可以在项目上使用Flexbox。由于Flexbox通常更适合对齐任何东西。

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  grid-gap: 20px;
  align-items: center;
  justify-content: center;
}

.container div {
  background-color: gray;
  height: 100px;
  display: flex;
  justify-content: center;
  align-items: center;
}
<div class="container">
  <div>Box 1</div>
  <div>Box 2</div>
  <div>Box 3</div>
  <div>Box 4</div>
</div>

You could use flexbox on the items, while using grid on the container. Since flexbox is generally more used to align anything.

.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  grid-gap: 20px;
  align-items: center;
  justify-content: center;
}

.container div {
  background-color: gray;
  height: 100px;
  display: flex;
  justify-content: center;
  align-items: center;
}
<div class="container">
  <div>Box 1</div>
  <div>Box 2</div>
  <div>Box 3</div>
  <div>Box 4</div>
</div>

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文