0

0

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

P粉602998670

P粉602998670

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

|

987人浏览过

|

来源于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 布局,<code>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 的复合结构。<p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p> <ul> <li>给单元格加 <code>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></p><div class="aritcle_card flexRow"> <div class="artcardd flexRow"> <a class="aritcle_card_img" href="/ai/2299" title="TemPolor"><img src="https://img.php.cn/upload/ai_manual/001/246/273/175738803212980.png" alt="TemPolor" onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a> <div class="aritcle_card_info flexColumn"> <a href="/ai/2299" title="TemPolor">TemPolor</a> <p>AI音乐生成器,一键创作免版税音乐</p> </div> <a href="/ai/2299" title="TemPolor" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a> </div> </div> 就会自动居中,其实不会。

    参数差异: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

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

    豆包大模型
    豆包大模型

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

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

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

    文心一言
    文心一言

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

    讯飞写作
    讯飞写作

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

    即梦AI
    即梦AI

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

    ChatGPT
    ChatGPT

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

    相关专题

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

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

    1051

    2023.08.11

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

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

    833

    2023.11.06

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

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

    829

    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字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

    739

    2023.08.03

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

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

    6120

    2023.08.17

    Go高并发任务调度与Goroutine池化实践
    Go高并发任务调度与Goroutine池化实践

    本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

    4

    2026.03.10

    热门下载

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

    相关下载

    更多

    精品课程

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

    共14课时 | 0.9万人学习

    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 3.5万人学习

    CSS教程
    CSS教程

    共754课时 | 41.3万人学习

    最新文章

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

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