八种方式实现垂直居中

79 阅读1分钟

首先如果 .parent 的 height 不写,你只需要 padding: 10px 0; 就能将 .child 垂直居中;

如果 .parent 的 height 写死了,就很难把 .child 居中,以下是垂直居中的方法。

忠告:能不写 height 就千万别写 height。

那么,下面介绍我总结的八种实现方法

1、直接使用table标签,它的子元素自带居中属性

2、使用标签把子元素夹在中间

.parent{
  border: 3px solid red;
  height: 600px;
  text-align: center;
}
.child{
  border: 3px solid black;
  display: inline-block;
  width: 300px;
  vertical-align: middle;
}
.parent .before{
  outline: 3px solid red;
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}
.parent .after{
  outline: 3px solid red;
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}

3、把div装成table

div.table{
  display: table;
  border: 1px solid red;
  height: 600px;
}
div.tr{
  display: table-row;
  border: 1px solid green;
}
div.td{
  display: table-cell;
  border: 1px solid blue;
  vertical-align: middle;
}
.child{
  border: 10px solid black;
}

4、绝对定位下调整参数方法1

.parent{
  height: 600px;
  border: 1px solid red;
  position: relative;
}
.child{
  border: 1px solid green;
  width: 300px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-left: -150px;
  height: 100px;
  margin-top: -50px;
}

5、绝对定位下调整参数方法2

.parent{
  height: 600px;
  border: 1px solid red;
  position: relative;
}
.child{
  border: 1px solid green;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}

6、绝对定位下调整参数方法3

.parent{
  height: 600px;
  border: 1px solid red;
  position: relative;
}
.child{
  border: 1px solid green;
  position: absolute;
  width: 300px;
  height: 200px;
  margin: auto;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}

7、grid布局

.parent{
  height: 600px;
  border: 3px solid red;
  display: grid;
  justify-items:center;
  align-items:center
}
.child{
  border: 3px solid green;
  width: 300px;
}

8、flex布局

.parent{
  height: 600px;
  border: 3px solid red;
  
  display: flex;
  justify-content: center;
  align-items: center;
}
.child{
  border: 3px solid green;
  width: 300px;
}