CSS专题之水平垂直居中
前言
石匠敲击石头的第 16 次
在日常开发中,经常会遇到水平垂直居中的布局,虽然现在基本上都用 Flex 可以轻松实现,但是在某些无法使用 Flex 的情况下,又应该如何让元素水平垂直居中呢?这也是一道面试的必考题,所以打算写一篇文章来好好梳理一下,如果哪里写的有问题欢迎指出,不胜感激。
分类
实现元素水平垂直居中的方法有很多,大致可以分为以下两类:
- 固定宽高元素适用的方法
- 不固定宽高元素适用的方法
我们先实现基础的布局,然后再分别讲每一类具体的方案。
.container {border: 1px solid red;width: 300px;height: 300px;
}.box {background: blue;color: #fff;
}.size {width: 100px;height: 100px;
}
<div class="container"><div class="box size">你好,世界</div>
</div>
固定宽高元素
absolute + 负 margin
.container {/* 其它的基础样式... */position: relative;
}.box {/* 其它的基础样式... */position: absolute;top: 50%;left: 50%;margin-left: -50px;margin-top: -50px;
}
该方案的原理非常简单,可以分为两步来看:
-
先通过绝对定位的
top: 50%
和left: 50%
使元素的左上角定位在.container
容器元素的中心位置 -
再通过
margin-top
和margin-left
设置为负值,具体值为元素宽度和高度的一半,例如这里元素的宽高都是100px
,所以一半就是50px
最终的效果如下
在线查看效果
✅ 优点: 兼容性好,适用于 IE 等老版本浏览器。
⚠️ 缺点:
- 需要提前知道元素大小,并且需要手动计算元素大小的一半
- 每次修改元素大小都需要同步修改
margin
值
absolute + margin: auto
.container {/* 其它的基础样式... */position: relative;
}.box {/* 其它的基础样式... */position: absolute;top: 0;left: 0;right: 0;bottom: 0;margin: auto;
}
该方案和前一个方案最终效果是一样,该方案的步骤如下:
- 通过设置绝对定位
top:0; bottom:0; left:0; right:0;
,让浏览器知道元素被限制”在父容器内四边,这样有了一个明确的空间范围 - 再通过设置
margin: auto
,浏览器就可以根据父容器大小 - 元素大小 = 剩余空间
,把剩余空间平分给margin: auto
,实现水平垂直方向上的居中
在线查看效果
✅ 优点:
- 兼容性好,适用于 IE 等老版本浏览器
- 每次修改元素大小不需要同步修改
margin
值,无需手动计算元素大小的一半
⚠️ 缺点: 只能用于固定尺寸的元素,不适合宽高不确定的情况。
absolute + calc
.container {/* 其它的基础样式... */position: relative;
}.box {/* 其它的基础样式... */position: absolute;top: calc(50% - 50px);left: calc(50% - 50px);
}
该方案与前面的 absolute + 负 margin 方案原理相同,使用了 calc
函数替代了 margin
负值来计算居中的位置。
在线查看效果
⚠️ 缺点:
- 该方案依赖
calc
函数的兼容性,具体兼容性可以参考 Can I use - 需要提前知道元素大小,修改元素大小需要同步修改
calc
函数中减去的值 - 相比前两个方案,该方案既缺乏兼容性(IE9+),又需要手动计算元素大小的一半,不推荐使用
不固定宽高元素
absolute + transform
.container {/* 其它的基础样式... */position: relative;
}.box {/* 其它的基础样式... */position: absolute;left: 50%;top: 50%;transform: translate(-50%, -50%);
}
该方案与前面的 absolute + 负 margin 方案原理相同,使用了 transform
替代了 margin
负值来计算居中的位置。
因为translate(-50%, -50%)
的百分比是相对于元素本身的宽高,所以不需要提前知道元素的具体尺寸。
在线查看效果
✅ 优点: 无需提前知道元素大小,修改元素大小不需要同步修改相关的值
⚠️ 缺点: 该方案依赖 transform()
函数的兼容性,具体兼容性可以参考 Can I use
line-height
.container {/* 其它的基础样式... */line-height: 300px;text-align: center;
}.box {/* 其它的基础样式... */display: inline-block;vertical-align: middle;line-height: initial;
}
该方案的实现步骤如下:
-
首先给
.container
容器设置一个与高度相同的行高,例如这里容器的高度为300px
,所以设置line-height: 300px
,并给容器设置text-align: center;
水平居中对齐 -
然后再给
.box
元素设置为行内块(inline-block)元素,并设置vertical-align: middle;
垂直居中对齐 -
居中效果有了,但是文字却不见了,因为
.container
容器的text-align
和line-height
默认是会被继承给.box
元素,这时我们需要通过line-height: initial
和text-align: initial
重置为初始值
在线查看效果
✅ 优点: 无需提前知道元素大小,修改元素大小不需要同步修改相关的值
⚠️ 缺点: 需要重置内部元素的文字样式
writing-mode
.container {/* 其它的基础样式... */writing-mode: vertical-lr;text-align: center;
}.inner {width: 100%;display: inline-block;writing-mode: horizontal-tb;
}.box {/* 其它的基础样式... */display: inline-block;text-align: initial;
}
<div class="container"><div class="inner"><div class="box">你好,世界</div></div>
</div>
该方案主要利用 writing-mode
属性,writing-mode
属性可以改变文字的显示方向
writing-mode: vertical-lr
让元素文字垂直方向显示writing-mode: horizontal-tb
让元素文字水平方向显示
该方案实现的步骤如下:
-
首先将
.container
容器的文字显示方向调整为垂直方向,并设置文字水平居中对齐,用来实现垂直居中 -
添加一个
.inner
包装元素,设置为行内块(inline-block)元素,并将宽度设置为100%
,并设置文字显示方向为水平方向,此时.container
容器的text-align: center;
被继承,变成了水平居中 -
最后将
.inner
包装元素内部的.box
元素调整为行内块(inline-block)元素,并重置继承的text-align
属性的值为初始值
在线查看效果
✅ 优点:
- 兼容性好,适用于 IE 等老版本浏览器
- 无需提前知道元素大小,修改元素大小不需要同步修改相关的值
⚠️ 缺点:
- 需要重置内部元素的文字样式
- 实现和理解起来有点复杂
- 需要额外的 DOM 元素
table
.container {/* 其它的基础样式... */text-align: center;
}.box {/* 其它的基础样式... */display: inline-block;text-align: initial;
}
<table><tbody><tr><td class="container"><div class="box">你好,世界</div></td></tr></tbody>
</table>
该方案利用了 <table>
标签中 <td>
单元格内容天然是垂直居中的特性,所以只需要再添加一个水平居中就可以实现水平垂直居中。
在线查看效果
✅ 优点:
- 兼容性好,适用于 IE 等老版本浏览器
- 无需提前知道元素大小,修改元素大小不需要同步修改相关的值
⚠️ 缺点:
- 代码冗余,需要额外的 DOM 元素
- 不符合
<table>
标签正确语义用法 - 需要重置内部元素的文字水平居中样式
display: table-cell
.container {/* 其它的基础样式... */display: table-cell;text-align: center;vertical-align: middle;
}.box {/* 其它的基础样式... */display: inline-block;text-align: initial;
}
该方案通过将 .container
容器变成 table
单元格显示效果,因为表格单元格的内容默认是垂直居中,在这基础上再加一个 text-align: center;
水平居中即可实现水平垂直居中效果。
在线查看效果
✅ 优点:
- 兼容性好,适用于 IE 等老版本浏览器
- 无需提前知道元素大小,修改元素大小不需要同步修改相关的值
- 相比
<table>
实现没有多余的 DOM 元素
⚠️ 缺点: 需要重置内部元素的文字水平居中样式
Flex
.container {/* 其它的基础样式... */display: flex;justify-content: center;align-items: center;
}
上面这段代码相信大家用的比较多了,我就不详细介绍了。不过 Flex 还有另外一种更加简便的实现方法:
.container {/* 其它的基础样式... */display: flex;
}.box {/* 其它的基础样式... */margin: auto;
}
这个方案利用了 Flex 布局中,Flex 子元素的 margin
被设置为 auto
,浏览器会将剩余空间平均分配的特性。
在线查看效果
✅ 优点:
- 无需提前知道元素大小,修改元素大小不需要同步修改相关的值
- 实现简单,代码量少
⚠️ 缺点: 只适合在现代浏览器中使用。
Grid
.container {/* 其它的基础样式... */display: grid;
}.box {/* 其它的基础样式... */align-self: center;justify-self: center;
}
在线查看效果
✅ 优点:
- 无需提前知道元素大小,修改元素大小不需要同步修改相关的值
- 实现简单,代码量少
⚠️ 缺点: 只适合在现代浏览器中使用,更加推荐使用 Flex。
总结
元素水平垂直居中的方案主要可以分为以下两类:
固定宽高元素适用的方案
方案 | 兼容性 | 备注 |
---|---|---|
absolute + 负 margin | ✅ 非常好(IE6+) | 最老牌的方案,手动计算偏移量 |
absolute + margin: auto | ✅ 非常好(IE8+) | 语义清晰,适合固定尺寸元素 |
absolute + calc() | ⚠️ 一般(IE9+) | 不推荐,既不方便也不通用 |
宽高不固定元素适用的方案
方案 | 兼容性 | 备注 |
---|---|---|
absolute + transform | ✅ 较好(IE9+) | 最常用,推荐优先考虑 |
line-height | ✅ 非常好(IE6+) | 适合单行文字,有继承问题需手动处理 |
writing-mode | ✅ 非常好(IE6+) | 实现和理解起来比较复杂,不推荐 |
<table> + text-align | ✅ 非常好(IE6+) | 结构语义不合理,适合邮件模板等场景 |
display: table-cell | ✅ 非常好(IE6+) | 替代表格结构,语义更合理 |
flex | ⚠️ 一般(IE10+) | 推荐使用,现代项目首选 |
flex + margin: auto | ⚠️ 一般(IE10+) | 更简洁,但仅适合单元素居中 |
grid | ⚠️ 较差(IE11 部分支持) | 简单强大,但需注意兼容性,不如 Flex 普遍 |
- 如果项目兼容性要求低,首选
flex + align/justify-center
或absolute + transform
方案 - 如果需要兼容 IE9 及以下浏览器,首选
absolute + 负 margin
或table-cell
方案
参考文章
- CSS实现水平垂直居中的10种方式划重点,这是一道面试必考题,很多面试官都喜欢问这个问题,我就被问过好几次了 要实现上图 - 掘金
- 实现元素水平+垂直居中的方法(持续更新)1. 父元素:flex flex这个东西简直就是一个神器… 这个时候子元素就 - 掘金
- 元素水平垂直居中常用方法汇总行内元素 line-height + text-align 行内块状元素 line-heig - 掘金
- 如何让一个元素水平垂直居中?(代码实例+方案总结) 超详细!!!!在日常的开发中,我们经常会面对这样一个问题:如何实现居 - 掘金
博客地址:https://github.com/wjw020206/blog
相关文章:

CSS专题之水平垂直居中
前言 石匠敲击石头的第 16 次 在日常开发中,经常会遇到水平垂直居中的布局,虽然现在基本上都用 Flex 可以轻松实现,但是在某些无法使用 Flex 的情况下,又应该如何让元素水平垂直居中呢?这也是一道面试的必考题…...
python打卡day41@浙大疏锦行
知识回顾 1. 数据增强 2. 卷积神经网络定义的写法 3. batch归一化:调整一个批次的分布,常用与图像数据 4. 特征图:只有卷积操作输出的才叫特征图 5. 调度器:直接修改基础学习率 卷积操作常见流程如下: 1. …...
vue3 基本语法 父子关系
在Vue 3中,父子组件的关系是通过组件的嵌套实现的。父组件可以传递数据(props)给子组件,同时子组件可以通过事件(emits)与父组件通信。下面是如何在Vue 3中建立和使用父子组件的基本语法: 1. 创…...
算法-js-子集
题:给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的子集(幂集)。解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。 方法一:迭代法 核心逻辑:动态扩展子集, 小规…...

(新)MQ高级-MQ的可靠性
消息到达MQ以后,如果MQ不能及时保存,也会导致消息丢失,所以MQ的可靠性也非常重要。 一、数据持久化 为了提升性能,默认情况下MQ的数据都是在内存存储的临时数据,重启后就会消失。为了保证数据的可靠性,必须…...
Android设置界面层级为最上层实现
Android设置界面层级为最上层实现 文章目录 Android设置界面层级为最上层实现一、前言二、Android设置界面层级为最上层实现1、主要代码2、后遗症 三、其他1、Android设置界面层级为最上层小结2、悬浮框的主要代码悬浮框 注意事项(1)权限限制(…...
云原生微服务架构演进之路:理念、挑战与实践
📝个人主页🌹:慌ZHANG-CSDN博客 🌹🌹期待您的关注 🌹🌹 一、引言:架构的演进是业务进化的技术反射 在软件行业的发展过程中,架构变迁总是伴随着技术浪潮与业务复杂度的升…...
Go语言使用阿里云模版短信服务
在当今的互联网项目中,短信验证码、通知等功能已成为标配。本文将详细介绍如何使用Go语言集成阿里云短信服务(DYSMSAPI)实现短信发送功能。 一、准备工作 在开始之前,您需要完成以下准备工作: 注册阿里云账号并实名认证开通短信服务(SMS)申…...

Leetcode 3231. 要删除的递增子序列的最小数量
1.题目基本信息 1.1.题目描述 给定一个整数数组 nums,你可以执行任意次下面的操作: 从数组删除一个 严格递增 的 子序列。 您的任务是找到使数组为 空 所需的 最小 操作数。 1.2.题目地址 https://leetcode.cn/problems/minimum-number-of-increas…...

4.2.5 Spark SQL 分区自动推断
在本节实战中,我们学习了Spark SQL的分区自动推断功能,这是一种提升查询性能的有效手段。通过创建具有不同分区的目录结构,并在这些目录中放置JSON文件,我们模拟了一个分区表的环境。使用Spark SQL读取这些数据时,Spar…...
基于昇腾MindSpeed训练加速库玩转智谱GLM-4-0414模型
智谱GLM-4-0414模型提供32B和9B两种参数规模,涵盖基础、推理和沉思等多种模型类型,均基于 MIT 许可协议开放。其中,推理模型 GLM-Z1-32B-0414 性能卓越,与 DeepSeek-R1 等领先模型相当,实测推理速度达每秒200个Tokens。…...

【图像处理入门】2. Python中OpenCV与Matplotlib的图像操作指南
一、环境准备 import cv2 import numpy as np import matplotlib.pyplot as plt# 配置中文字体显示(可选) plt.rcParams[font.sans-serif] [SimHei] plt.rcParams[axes.unicode_minus] False二、图像的基本操作 1. 图像读取、显示与保存 使用OpenCV…...

Spring Boot微服务架构(九):设计哲学是什么?
一、Spring Boot设计哲学是什么? Spring Boot 的设计哲学可以概括为 “约定优于配置” 和 “开箱即用”,其核心目标是极大地简化基于 Spring 框架的生产级应用的初始搭建和开发过程,让开发者能够快速启动并运行项目…...
GRCh38版本染色体位置转换GRCh37(hg19)
目录 方法 1:使用 Ensembl REST API(推荐,适用于少量位点查询)方法 2:使用 UCSC API方法 3:使用 NCBI API 并转换坐标(需要额外步骤)方法 4:使用本地数据库(最…...

TC/BC/OC P2P/E2E有啥区别?-PTP协议基础概念介绍
前言 时间同步网络中的每个节点,都被称为时钟,PTP协议定义了三种基本时钟节点。本文将介绍这三种类型的时钟,以及gPTP在同步机制上与其他机制的区别 本系列文章将由浅入深的带你了解gPTP,欢迎关注 时钟类型 在PTP中我们将各节…...
解决微信小程序中 Flex 布局下 margin-right 不生效的问题
解决微信小程序中 Flex 布局下 margin-right 不生效的问题 在做微信小程序开发时,遇到了一个棘手的布局问题:在 flex 布局下,给元素设置的 margin-right 不生效,被“吞噬”了。这个问题导致了横向滚动列表的右边距失效࿰…...

Kafka数据怎么保障不丢失
在分布式消息系统中,数据不丢失是核心可靠性需求之一。Apache Kafka 通过生产者配置、副本机制、持久化策略、消费者偏移量管理等多层机制保障数据可靠性。以下从不同维度解析 Kafka 数据不丢失的核心策略,并附示意图辅助理解。 一、生产者端:…...
使用HTTPS进行传输加密
说明 日期:2025年5月30日 与以纯文本形式发送和接收消息的标准 HTTP 不同,HTTPS 使用SSL/TLS等协议对服务器进行身份验证、加密通信内容和检测篡改。 这样可以防止欺骗、中间人攻击和窃听等攻击。 证书很重要,如果用户主动信任了伪造证书&…...

AI书签管理工具开发全记录(八):Ai创建书签功能实现
文章目录 AI书签管理工具开发全记录(八):AI智能创建书签功能深度解析前言 📝1. AI功能设计思路 🧠1.1 传统书签创建的痛点1.2 AI解决方案设计 2. 后端API实现 ⚙️2.1 新增url相关工具方法2.1 创建后端api2.2 创建crea…...

X-plore v4.43.05 强大的安卓文件管理器-MOD解锁高级版 手机平板/电视TV通用
X-plore v4.43.05 强大的安卓文件管理器-MOD解锁高级版 手机平板/电视TV通用 应用简介: X-plore 是一款强大的安卓端文件管理器,它可以在电视或者手机上管理大量媒体文件、应用程序。…...

使用多Agent进行海报生成的技术方案及评估套件-P2P、paper2poster
最近字节、滑铁卢大学相关团队同时放出了他们使用Agent进行海报生成的技术方案,P2P和Paper2Poster,传统方案如类似ppt生成等思路,基本上采用固定的模版,提取相关的关键元素进行模版填充,因此,海报生成的质量…...

Redis--缓存工具封装
经过前面的学习,发现缓存中的问题,无论是缓存穿透,缓存雪崩,还是缓存击穿,这些问题的解决方案业务代码逻辑都很复杂,我们也不应该每次都来重写这些逻辑,我们可以将其封装成工具。而在封装的时候…...

python:在 PyMOL 中如何查看和使用内置示例文件?
参阅:开源版PyMol安装保姆级教程 百度网盘下载 提取码:csub pip show pymol 简介: PyMOL是一个Python增强的分子图形工具。它擅长蛋白质、小分子、密度、表面和轨迹的3D可视化。它还包括分子编辑、射线追踪和动画。 可视化示例:打开 PyM…...

SpringCloud——Docker
1.命令解读 docker run -d 解释:创建并运行一个容器,-d则是让容器以后台进程运行 --name mysql 解释: 给容器起个名字叫mysql -p 3306:3306 解释:-p 宿主机端口:容器内端口,设置端口映射 注意: 1、…...

机器学习:欠拟合、过拟合、正则化
本文目录: 一、欠拟合二、过拟合三、拟合问题原因及解决办法四、正则化:尽量减少高次幂特征的影响(一)L1正则化(二)L2正则化(三)L1正则化与L2正则化的对比 五、正好拟合代码…...

运用集合知识做斗地主案例
方法中可变参数 一种特殊形参,定义在方法,构造器的形参列表里,格式:数据类型...参数名称; 可变参数的特点和好处 特点:可以不传数据给它;可以传一个或者同时传多个数据给它;也可以…...

《HelloGitHub》第 110 期
兴趣是最好的老师,HelloGitHub 让你对开源感兴趣! 简介 HelloGitHub 分享 GitHub 上有趣、入门级的开源项目。 github.com/521xueweihan/HelloGitHub 这里有实战项目、入门教程、黑科技、开源书籍、大厂开源项目等,涵盖多种编程语言 Python、…...

使用 Shell 脚本实现 Spring Boot 项目自动化部署到 Docker(Ubuntu 服务器)
使用 Shell 脚本实现 Spring Boot 项目自动化部署到 Docker(Ubuntu 服务器) 在日常项目开发中,我们经常会将 Spring Boot 项目打包并部署到服务器上的 Docker 环境中。为了提升效率、减少重复操作,我们可以通过 Shell 脚本实现自动…...

day023-网络基础与OSI七层模型
文章目录 1. 网络基础知识点1.1 网络中的单位1.2 查看实时网速:iftop1.3 交换机、路由器 2. 路由表2.1 查看路由表的命令2.2 路由追踪命令 3. 通用网站网络架构4. 局域网上网原理-NAT5. 虚拟机上网原理6. 虚拟机的网络模式6.1 NAT模式6.2 桥接模式6.3 仅主机模式 7.…...

SpringAI系列4: Tool Calling 工具调用 【感觉这版本有bug】
前言:在最近发布的 Spring AI 1.0.0.M6 版本中,其中一个重大变化是 Function Calling 被废弃,被 Tool Calling 取代。Tool Calling工具调用(也称为函数调用)是AI应用中的常见模式,允许模型通过一组API或工具…...