垂直居中用 align-items: center(flex)或 place-items: center(grid);父容器须设 display: flex/grid 和明确高度(如 min-height: 100vh),否则居中失效。
align-items 还是 justify-content?垂直居中靠 align-items: center,但前提是父容器设了 display: flex 且有明确高度(或能撑开高度)。justify-content: center 管水平,别混用。
常见错误是父容器没设高度,比如只写了 height: 100% 却没给祖先元素设高,结果子元素“塌”在顶部。推荐用 min-height: 100vh 保底。
实操建议:
display: flex 和 align-items: center
justify-content: center 实现水平+垂直居中margin: auto
margin-top: 50% 或 transform: translateY(-50%) —— 这是老办法,flex 下多余.container {
display: flex;
align-items: center;
justify-content: center;
min-height: 100vh;
}
.item {
/ 不需要 margin 或 transform /
}
place-items 一行解决place-items: center 是 justify-items 和 align-items 的简写,对 grid 容器内所有直接子项生效。它比 flex 更“无感”——不需要关心子项是否单个、是否换行。
注意:它只作用于 grid 子项(即 grid-item),不是后代元素。如果中间嵌套了一层 div,那层必须也设为 display: contents 或直接去掉。
实操建议:
display: grid + place-items: center 即可grid-template-rows 或 grid-template-columns,自动创建隐式网格justify-self: center; align-self: center
.container {
display: grid;
place-items: center;
min-height: 100vh;
}flex 默认是单行布局(flex-wrap: nowrap),多个子项会横向挤在一起;grid 默认是多行网格,每个子项占一个格子。这意味着:
place-items: center:每个子项各自在自己的网格单元里居中,视觉上可能错落(除非显式设 grid-template-columns: repeat(1, 1fr))flex-direction: column);grid 则需配合 grid-auto-flow: column 或明确行列定义性能上无明显差别,但 grid 在复杂二维布局中扩展性更强;flex 更适合一维流式场景。
如果父容器本身是浮动元素(float: left)、绝对定位(position: absolute)但没设宽高,或者被 overflow: hidden 截断,flex/grid 的居中会失效——因为容器“不可见高度”。
另一个高频问题:使用 vh 单位时,页面有滚动条导致视口高度计算偏差。iOS Safari

100vh 的处理尤其不稳定,建议用 100dvh(如支持)或 JS 动态设置高度。
调试建议:
outline: 1px solid red 看父容器是否“存在”overflow 相关样式,逐步排查真正卡住的时候,往往不是居中逻辑错了,而是容器根本没拿到高度。