CSS实现垂直居中的7种方法总结

110 阅读1分钟
前提条件
  1. 如果 .parent 的 height 不写,你只需要 padding: 10px 0; 就能将 .child 垂直居中
  2. 写死
    • width: 100px
  3. 不写死
    • width: 500
    • max-width: 100px
    • width: 30vw
    • min-width: 80%
    • 特点:不使用px,或者加 min max前缀
  4. 如果 .parent 的 height 写死了,就很难把 .child 居中,以下是总结的垂直居中方法。
1.table自带功能
<style>
 .parent{
  border: 1px solid red;
  height: 600px;
}

.child{
  border: 1px solid green;
}
  </style>
<body>
  <table class="parent">
    <tr>
      <td class="child">
           这是一段垂直居中的文字
      </td>
    </tr>
  </table>
</body>
2.div装成table
<style>
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;
}
</style>
<body>
  <div class="table">
      <div class="td">
        <div class="child">
         这是一段垂直居中的文字
        </div>
    </div>
  </div>
</body>
3.100% 高度的 afrer before 加上 inline block
<style>
.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,.parent:after{
  content:'';
  outline: 3px solid red;
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}

</style>
<body>
  <div class="parent">
    <div class="child">
      这是一段垂直居中的文字
    </div>
  </div>
</body>
4.margin-top -50%
<style>
  .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;
}
</style>
<body>
  <div class="parent">
    <div class="child">
     这是一段垂直居中的文字
    </div>
  </div>
</body>
5.translate -50%
<style>
.parent{
  height: 600px;
  border: 1px solid red;
  position: relative;
}
.child{
  border: 1px solid green;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}
</style>
<body>
  <div class="parent">
    <div class="child">
      这是一段垂直居中的文字
    </div>
  </div>
</body>
6. absolute margin auto
<style>
.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;
}
</style>
<body>
  <div class="parent">
    <div class="child">
    这是一段垂直居中的文字
    </div>
  </div>
</body>
7. flex
<style>
.parent{
  height: 600px;
  border: 3px solid red;
  display: flex;
  justify-content: center;
  align-items: center;
}
.child{
  border: 3px solid green;
  width: 300px;
}
</style>
<body>
  <div class="parent">
    <div class="child">
     这是一段垂直居中的文字
    </div>
  </div>
</body>