实现元素水平+垂直居中的方法(持续更新)

1,104 阅读1分钟

实现元素水平 + 垂直居中

元素水平居中,这个实现起来就很简单。
文字可以用text-align:center;
有宽度的块级元素可以用margin:0 auto;

那如果想要元素水平+ 垂直居中呢?要是元素的宽高还不确定呢?

1. 父元素:flex

flex这个东西简直就是一个神器...

我们给父元素设置flex相关属性:

display: flex;
justify-content: center;
align-items: center;

这个时候子元素就会在父盒子内部水平+垂直居中了。

水平垂直居中flex.png

2. 子元素:绝对定位 + margin

给子元素设置绝对定位,让子元素相对父元素向右、向下移动父元素宽高的50%,然后再用margin-top和margin-left的负值,往回拉子元素自己宽高的50%。

/* 给父元素设置: */
position: relative;


/* 给子元素设置: */

width: 100px;
height: 100px;
background-color: orange;

position: absolute;
top: 50%;
left: 50%;
margin-top: -50px;
margin-left: -50px;

这个方法比较坑的一个点就是,你得知道子元素自己的宽高才行,不然margin值就控制不好子元素往回拉的距离。

3. 子元素:绝对定位 + transform 位移

transform的translate设置的百分比,是相对于子元素本身的,所以我们可以给子元素设置 -50% ,来解决上一个方法的坑。

/* 父元素还是加一个相对定位 */


/* 子元素设置一下属性 */
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%,-50%);

4. 子元素绝对定位 + 上下左右为0 + margin为auto

/* 父元素相对定位 */

/* 子元素设置绝对定位   上右下左都为0   margin为auto */

position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
        
margin: auto;

这个方法思路还是比较新奇的。