CSS中垂直居中的七种方法

article/2025/6/23 22:31:24

前言:

我们在编辑一个版面,通常都会用到水平居中和垂直居中来设计,而水平居中很好处理,不外乎就是设定margin:0 auto;或是text-align:center;,就可以轻松解决掉水平居中的问题,但一直以来最麻烦对齐问题,都是“垂直居中”这个讨人厌的设定,以下将介绍七种单纯利用CSS垂直居中的方式。

七种垂直居中的方法 :

  1. 设定行高(line-height)
  2. 添加伪元素
  3. calc动态计算
  4. 使用表格或假装表格
  5. transform
  6. 绝对定位
  7. 使用Flexbox

设定行高(line-height):

       设定行高是垂直居中最简单的方式,适用于“单行”的“行内元素”(inline、inline-block),例如单行的标题,或是已经设为inline-block属性的div,若将line-height设成和高度一样的数值,则内容的行内元素就会被垂直居中,因为是行高,所以会在行内元素的上下都加上行高的1/2,所以就垂直居中了!不过由此就可以看出,为什么必须要单行的行内元素,因为如果多行,第二行与第一行的间距会变超大,就不是我们所期望的效果了。

CSS示例:

.div0{width:200px;height:150px;border:1px solid #000;line-height:150px;text-align:center;
}
.redbox{display:inline-block;width:30px;height:30px;background:#c00;
}

                                              

 添加伪元素(::before、::after)

       第一种方法,虽然是最简单的方法(适用于单行标题),不过就是只能单行,所以我们如果要让多行的元素也可以垂直居中,就必须要使用伪元素的方式。在此之前,先解释一下CSS里头vertical-align这个属性,这个属性虽然是垂直居中,不过却是指在元素内的所有元素垂直位置互相居中,并不是相对于外框的高度垂直居中。(下面的CSS会造成这种样子的垂直居中)                                  

.div0{width:200px;height:150px;border:1px solid #000;text-align:center;
}
.redbox{width:30px;height:30px;background:#c00;display:inline-block;vertical-align:middle;
}
.greenbox{width:30px;height:60px;background:#0c0;display:inline-block;vertical-align:middle;
}
.bluebox{width:30px;height:40px;background:#00f;display:inline-block;vertical-align:middle;
}

                                                   

 因此,如果有一个方块变成了高度100%,那么其他的方块就会真正的垂直居中

.greenbox{width:30px;height:100%;background:#0c0;display:inline-block;vertical-align:middle;
}

                                                  

       但是我们总不能每次要垂直居中,都要添加一个奇怪的div在里头吧!所以我们就要把脑筋动到“伪元素”身上,利用::before和::after添加div进到杠杠内,让这个“伪”div的高度100%,就可以轻松地让其他的div都居中。不过不过不过!div记得要把display设为inline-block,毕竟vertical-align:middle;是针对行内元素,div本身是block,所以必须要做更改!

.div0::before{content:'';width:0;height:100%;display:inline-block;position:relative;vertical-align:middle;background:#f00;
}

                                              

 calc动态计算

       看到这边或许会有疑问,如果今天我的div必须要是block,我该怎么让它垂直居中呢?这时候就必须用到CSS特有的calc动态计算的能力,我们只要让要居中的div的top属性,与上方的距离是“50%的外框高度+ 50%的div高度”,就可以做到垂直居中,至于为什么不用margin-top,因为margin相对的是水平宽度,必须要用top才会正确。

.div0{width:200px;height:150px;border:1px solid #000;
}
.redbox{width:30px;height:30px;background:#c00;float:left;top:calc(50% - 15px);margin-left:calc(50% - 45px);
}
.greenbox{width:30px;height:80px;background:#0c0;float:left;top:calc(50% - 40px);
}
.bluebox{width:30px;height:40px;background:#00f;float:left;top:calc(50% - 20px);
}

                                            

使用表格或假装表格 

       或许有些人会发现,在表格这个HTML里面常用的DOM里头,要实现垂直居中是相当容易的,只需要下一行vertical-align:middle就可以,为什么呢?最主要的原因就在于table的display是table,而td的display是table-cell,所以我们除了直接使用表格之外,也可以将要垂直居中元素的父元素的display改为table-cell,就可以轻松达成,不过修改display有时候也会造成其他样式属性的连动影响,需要比较小心使用。

HTML:

<table><tr><td><div>表格垂直居中</div></td></tr>
</table>
<div class="like-table"><div>假的表格垂直居中</div>
</div

CSS:

.like-table{display:table-cell;
}
td,
.like-table{width:150px;height:100px;border:1px solid #000;vertical-align: middle;
}
td div,
.like-table div{width:100px;height:50px;margin:0 auto;color:#fff;font-size:12px;line-height: 50px;text-align: center;background:#c00;
}
.like-table div{background:#069;
}

                               

 transform

     transform是CSS3的新属性,主要掌管元素的变形、旋转和位移,利用transform里头的translateY(改变垂直的位移,如果使用百分比为单位,则是以元素本身的长宽为基准),搭配元素本身的top属性,就可以做出垂直居中的效果,比较需要注意的地方是,子元素必须要加上position:relative,不然就会没有效果。

.use-transform{width:200px;height:200px;border:1px solid #000;
}
.use-transform div{position: relative;width:100px;height:50px;top:50%;transform:translateY(-50%);background:#095;
}

                                            

绝对定位: 

       绝对定位就是CSS里头的position:absolute,利用绝对位置来指定,但垂直居中的做法又和我们正统的绝对位置不太相同,是要将上下左右的数值都设为0,再搭配一个margin:auto,就可以办到垂直居中,不过要特别注意的是,设定绝对定位的子元素,其父元素的position必须要指定为relative!而且绝对定位的元素是会互相覆盖的,所以如果内容元素较多,可能就会有些问题

.use-absolute{position: relative;width:200px;height:150px;border:1px solid #000;
}
.use-absolute div{position: absolute;width:100px;height:50px;top:0;right:0;bottom:0;left:0;margin:auto;background:#f60;
}

                                                  

使用Flexbox 

 使用align-items或justify-content的属性,轻轻松松就可以做到垂直居中的效果。

.use-flexbox{display:flex;align-items:center;justify-content:center;width:200px;height:150px;border:1px solid #000;
}
.use-flexbox div{width:100px;height:50px;background:#099;
}

                                                   

以上就是一些垂直居中的方法,由于垂直居中往往会动用到修改display这个属性,往往也会在排版上造成一些影响,例如不该用flexbox的地方如果用了flexbox,不该用table的地方用了table,不该用inline-block的地方用了inline-block,后续反而要多写许多其他的定位样式来修正,那就有点本末倒置了,因此如何活用这些CSS垂直居中的方法,就要看大家的版面结构而灵活运用!


http://chatgpt.dhexx.cn/article/bAL07FFo.shtml

相关文章

CSS文本垂直居中的几种方法

观看更佳-点击前往 一、单行文本的居中 1.文字水平居中 <div classbox style"text-align: center;">hello world</div>2.文本垂直水平居中 <div class"box2" style"width:150px;height:100px;line-height: 100px;">文本垂直…

css如何设置文本垂直居中显示,css中怎么设置文本居中?css文本垂直居中的设置方法...

在网页设计的过程中&#xff0c;有时候可能为了布局美观可能需要让文本居中&#xff0c;那么&#xff0c;怎么设置文本居中呢&#xff1f;本篇文章将给大家介绍关于css设置文本垂直居中的方法。 首先我们要知道通过css实现元素的水平居中较为简单&#xff1a;对文本&#xff0c…

css表格怎么垂直居中对齐,css表格垂直居中怎么设置?

css设置表格垂直居中的方法&#xff1a;1、在表格外面嵌套一层table&#xff0c;用table中的td来控制居中。2、将表格放在div标签中&#xff0c;通过为div设置css样式display:table-cell实现垂直居中。 css设置表格垂直居中的方法&#xff1a;1、在表格外面嵌套一层table&#…

竖排文字垂直居中css样式

竖排文字垂直居中css样式 <div class"item"><p class"bgcolor-green">A0001</p><p class"bgcolor-yellow">A0002</p><p class"bgcolor-red">A0003</p><p class"bgcolor-green"…

CSS实现水平垂直居中的五种方法

前言 今天来看看一个之前困扰我很久的问题&#xff0c;在CSS中&#xff0c;水平垂直居中&#xff0c;能有几种写法。 方法一&#xff1a;margin:auto 子绝父相&#xff0c;当元素绝对定位的时候&#xff0c;会根据最近父元素进行定位&#xff0c;利用这个特性&#xff0c;我…

CSS 元素垂直居中的 6种方法

转自&#xff1a;http://blog.zhourunsheng.com/2012/03/css-%E5%85%83%E7%B4%A0%E5%9E%82%E7%9B%B4%E5%B1%85%E4%B8%AD%E7%9A%84-6%E7%A7%8D%E6%96%B9%E6%B3%95/ 利用CSS进行元素的水平居中&#xff0c;比较简单&#xff0c;行级元素设置其父元素的text-align center&#xff…

使用 CSS 实现垂直居中的8种方法

​​​​​​CSS垂直居中的8种方法 目录 ​​​​​​CSS垂直居中的8种方法 1、通过vertical-align:middle实现CSS垂直居中。 2、通过display:flex实现CSS垂直居中。 3、通过伪元素:before实现CSS垂直居中。 4、通过display:table-cell实现CSS垂直居中。 5、通过隐藏节点…

css垂直居中的6种方式

在线demo演示地址&#xff1a;https://rondsjinhuajin.github.io/demo/index.html 个人博客主页&#xff1a;KinHKin的博客_CSDN博客-vue,中秋活动,性能优化领域博主 使用人群&#xff1a;前端面试&#xff0c;日常开发小技巧 目录 1、效果演示如下 ​编辑 1、使用display:…

css 居中问题的总结

1.css让浮动的盒子水平居中 解决方法&#xff1a; 给浮动的盒子加一个父盒子&#xff0c;设置宽度跟浮动盒子一样大小&#xff0c;并且overflow:hidden; 设置该盒子为margin: 0 auto; <!DOCTYPE html> <html lang"en"> <head><meta charset&qu…

CSS实现垂直居中的十五种方法

情景一&#xff1a;单行文字垂直居中 1、line-height 原理是在于将单行文字的行高设定后&#xff0c;文字会位于行高的垂直中间位置 <div class"text-con">单行文字垂直居中</div><style>.text-con {width: 200px;height: 60px;line-height: 60px…

CSS垂直居中的10种实现姿势

前言 前端开发中元素居中是最常见和最经常使用到的css技巧&#xff0c;不仅开发中经常会用到&#xff0c;面试官出题考核基础时有时候也会问道这类问题。本文主要介绍10种垂直居中的方法。希望对你我都有帮组。 1、line-heightheight实现 如果子元素是行内文本元素的话&…

CSS 垂直居中的七种方法——史上最详细总结

博主目前在蚂蚁集团-体验技术部&#xff0c;AntV/S2 是博主所在团队的开源项目——多维交叉分析表格&#xff0c;欢迎使用&#xff0c;感谢到 S2 github 仓库点赞 star&#xff0c;有任何关于前端面试、就业、技术问题都可给在文章后留言。 我们在写页面时&#xff0c;通常会用…

严题集6.65//Leetcode105 已知二叉树前序序列和中序序列分别存放在两个一位数组中,建立该二叉树的二叉链表

一、问题描述 注意可以假设数组中没有重复元素&#xff0c;这位我们判断子树是否为空时提供了便利。 二、DVC版本 先是在DVEC上编译的&#xff0c;供读者参考。 后面有LeetCode版的。 BiTree Resume_BiTree(TElemType *pre,TElemType *mid,int prelen,int midlen) //6-65 前…

二叉树的前序序列、中序序列、后序序列、层次序列

前序序列根 左子树 右子树&#xff0c;中序序列左子树 根 右子树&#xff0c;后序序列左子树 右子树 根&#xff0c;层次序列根 第二层从左到右 第三层从左到右 以此类推。中序序列又称为对称序列。 前序序列第一个节点为根节点&#xff0c;后序序列最后一个节点为根节点&…

331.验证二叉树的前序序列化

如果只给一个前序遍历&#xff0c;是不能构造出二叉树的&#xff0c;但是把空节点也加上&#xff0c;就可以唯一构造一个二叉树&#xff0c;按要求模拟一遍&#xff1a; 代码的执行过程被唯一限制住&#xff0c;还有一类是最优化问题&#xff0c;用算法解决该类问题。 class …

【数据结构】二叉树的链式存储结构(通过前序序列和中序序列构造二叉树

说明&#xff1a;需要分别输入要二叉树的前序序列和中序序列才能构建二叉树。如果构建失败&#xff0c;程序会报错。 比如我们给定一个二叉树&#xff0c;容易知道 前序序列为&#xff1a;GDAFEMHZ 中序序列为&#xff1a;ADEFGHMZ 程序运行结果&#xff1a; 源代码 #include&…

二叉树:已知前序序列与后序序列建树

二叉树&#xff1a;已知前序与后序建树 已知前序与中序、后序与中序建树是常遇到的算法问题。若已知前序序列与后序序列&#xff0c;要求输出满足条件的树的个数或者输出所有可能的树的中序序列&#xff0c;该怎么解决&#xff1f;下面我们一步步讨论这个问题。 首先&#xf…

LeetCode 每日一题331. 验证二叉树的前序序列化

331. 验证二叉树的前序序列化 序列化二叉树的一种方法是使用前序遍历。当我们遇到一个非空节点时&#xff0c;我们可以记录下这个节点的值。如果它是一个空节点&#xff0c;我们可以使用一个标记值记录&#xff0c;例如 #。 _9_/ \3 2/ \ / \4 1 # 6 / \ / \ / …

试证明:已知二叉树的前序序列和中序序列,可以唯一确定该二叉树

假设二叉树BT的总的结点个数为n&#xff0c;前序序列pre为&#xff0c;中序序列pin为&#xff0c;现用数学归纳法证明pre和pin可以唯一确定这棵二叉树&#xff1a; 1. n 1时&#xff0c;前序和中序序列都各只有一个元素&#xff0c;&#xff0c;此时等于&#xff0c;为BT的根…

验证二叉树的前序序列化[抽象前序遍历]

抽象前序遍历 前言一、验证二叉树的前序序列化二、抽象前序遍历总结参考文献 前言 难题要么复杂&#xff0c;要么未知&#xff0c;要么就是抽象考察&#xff0c;这三种类型都比较锻炼分析问题的能力。 一、验证二叉树的前序序列化 二、抽象前序遍历 package everyday.tree;p…