贝利信息

css grid布局与垂直与水平居中_双向居中技巧

日期:2026-01-14 00:00 / 作者:P粉602998670
place-items: center 是最简居中方案,但需父容器有高度(如 min-height: 100vh),否则塌陷失效;兼容现代浏览器,IE 不支持;单元素居中用 place-self: center;可拆分为 justify-items 和 align-items 便于调试;Grid 与 Flex 的 align-items 作用域不同,勿混用 display。

place-items: center 是最简方案,但容器必须有高度

直接写 place-items: center 就能同时搞定水平和垂直居中,前提是父容器得“撑开”——比如设 height: 100vhmin-height: 100vh,或嵌套在 flex 容器里。否则 Grid 容器高度塌陷,子元素看似没动,其实是被挤在顶部了。

只想居中某一个子项?用 place-self 而不是 place-items

place-items 是作用于整个容器的,所有子项都会被居中;而 place-self: center 只影响单个元素,其他子项照常按默认网格流排列——这点在卡片列表、弹窗、通知气泡等场景特别实用。

align-items + justify-items 分开写,更易调试和扩展

place-items: center 是简写,等价于 justify-items: center; align-items: center;。分开写的好处是:可以单独调整某一个方向,比如只水平居中(justify-items: center)、或只垂直居中(align-items: center),也方便后续加响应式断点。

当 Grid 不适用时,flexbox 是最稳妥的替代方案

虽然 Grid 居中更“二维”,但如果你的布局本质是一维(比如仅需上下左右居中一个模态框),用

Flex 更轻量、语义更清晰,且兼容性略好(Flex 从 Chrome 29 就开始支持)。

Grid 居中真正难的不是写哪行代码,而是意识到:它不解决“容器有没有高度”这个问题——这个坑,90% 的人第一次用时都踩过。