0

0

CSS如何实现网格单元格的内容垂直居中_利用align-items:center设置css

P粉602998670

P粉602998670

发布时间:2026-03-10 13:48:11

|

1007人浏览过

|

来源于php中文网

原创

align-items: center 在 grid 容器上没效果,是因为它只控制网格项在行轨道内的对齐,不作用于项内嵌套内容;若单元格内容需居中,应让该单元格自身设为 display: flex 并使用 align-items: center。

css如何实现网格单元格的内容垂直居中_利用align-items:center设置css

align-items: center 在 grid 容器上为什么没效果

因为 align-items 控制的是**整个网格容器内所有行轨道(grid rows)的对齐方式**,它只在容器是 display: grid 且子元素是直接子项(grid items)时才起作用。如果单元格里套了一层 <div> 或文本被包裹在其他标签里,而你又没给那层内部容器设高度或 flex 布局,align-items: center 就只是把“那整块内容”在行方向上居中——但内容本身可能还是顶部贴边。

常见错误现象:align-items: center 写了,文字依然顶着单元格上边;检查 computed styles 发现 grid item 高度是 auto,没有撑开。

  • 确保父容器是 display: grid,且目标单元格是它的**直接子元素**
  • 如果单元格内容需要独立控制对齐(比如里面还有图标+文字),建议让该单元格自身也变成 display: flex,再用 align-items: center
  • 不要依赖 grid 容器的 align-items 去居中“单元格内部的任意嵌套内容”

grid 单元格内文字垂直居中的可靠写法

最稳的方式不是靠容器的 align-items,而是让单元格自己成为 flex 容器。这样控制粒度更细,兼容性也好(Chrome 29+/Firefox 20+/Safari 10.1+ 都支持)。

使用场景:表格式布局中,每个 <div class="cell"> 需要文字上下居中,不管内容是一行、两行还是带 icon 的复合结构。

立即学习前端免费学习笔记(深入)”;

飞书多维表格
飞书多维表格

表格形态的AI工作流搭建工具,支持批量化的AI创作与分析任务,接入DeepSeek R1满血版

下载
  • 给单元格加 display: flex + align-items: center + justify-content: center(后者可选,如需水平也居中)
  • 必须设 heightmin-height,否则 flex 无法计算可用空间;常用 height: 100%(前提是父 grid row 高度固定或有约束)
  • 避免对单元格设 line-height 居中——它只对单行文本有效,换行就错位

示例:

.cell {
  display: flex;
  align-items: center;
  height: 40px;
  padding: 0 12px;
}

align-items 和 justify-items 混用时的误区

align-items 管垂直(cross axis),justify-items 管水平(main axis),但它们都只作用于**grid item 自身的盒模型位置**,不是 item 内部内容。很多人以为设了这两个,里面的 <p> 就会自动居中,其实不会。

参数差异:justify-items: center 让每个 grid item 在列轨道内水平居中;align-items: center 让每个 item 在行轨道内垂直居中——但 item 的内容是否居中,仍取决于 item 自己的布局方式。

  • 如果 grid item 是 div 且无额外样式,它默认是 display: block,内容依然按普通文档流渲染
  • 想让 item 内部文字居中,要么让它变 flex,要么用 text-align: center(仅限行内内容)+ line-height == height(仅限单行)
  • 不要在 grid 容器上同时滥用 align-items 和对每个 item 单独设 flex——容易叠加出意料之外的偏移

IE11 下 grid 垂直居中的替代方案

IE11 的 display: grid 不支持 align-itemsjustify-items(只支持旧语法 -ms-grid),所以不能依赖这些属性做居中。此时最可行的 fallback 是用 display: table-cell + vertical-align: middle

性能影响:table-cell 渲染路径比 flex 稍重,但在现代浏览器中几乎不可测;关键是它在 IE11 中稳定、无需 JS 补丁。

  • 对单元格设 display: table-cellvertical-align: middlewidthheight
  • 必须配合 display: table 的父容器(即 grid 容器退化为 table 布局,意味着放弃 grid 的响应式能力)
  • 更现实的做法:用 @supports 检测 display: grid 支持,只对不支持的 UA 启用 table-cell 规则

示例:

@supports not (display: grid) {
  .grid { display: table; }
  .cell { display: table-cell; vertical-align: middle; }
}

实际项目里最容易被忽略的,是 grid item 的 height 是否真正生效——很多时候它被 min-contentauto 卡住,导致 align-items 失去参照基准。先确认高度,再谈居中。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1057

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

838

2023.11.06

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

870

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

30

2025.12.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6207

2023.08.17

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号