CSS-七种方式实现垂直居中

一、table自带功能

HTML

<body>
<table class="parent">
<tr>
<td class="child">
这是文字这是文字这是文字
</td>
</tr>
</table>
</body>

CSS

.parent {
  border: 1px solid red;
  height: 300px;
}
.child {
  border: 1px soild green;
}

二、100%高度的after、before加上inline block

HTML

<body>
  <div class="parent">
    <span class="before"></span>
    <div class="child"> 这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字
    </div><span class="after"></span>
  </div>
</body>

CSS

.parent {
  border: 3px solid red;
  height: 300px;
  text-align: center;
}
.child {
  border: 3px solid black;
  display: inline-block;
  width:150px;
  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;
}

三、div装成table

HTML

<body>
  <div class="table">
    <div class="td">
      <div class="child">
        这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字
      </div>
    </div>
  </div>
</body>

CSS

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: 5px solid black;
}

四、margin-top:-50px

HTML

<body>
  <div class="parent">
      <div class="child">
        这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字
      </div>
  </div>
</body>

CSS

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

五、transform: translate(-50%,-50%)

HTML

<body>
  <div class="parent">
    <div class="child">
      这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字
    </div>
  </div>
</body>

CSS

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

六、position: absolute; margin: auto;

HTML

<body>
  <div class="parent">
    <div class="child">
      这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字
    </div>
  </div>
</body>

CSS

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

七、flex布局 justify-content: center; align-items: center;

HTMl

<body>
  <div class="parent">
    <div class="child">
      这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字
    </div>
  </div>
</body>

CSS

.parent {
  border: 1px solid red;
  height: 300px;
 display: flex;
  justify-content: center;
  align-items: center;
}
.child {
  border: 1px solid green;
  width: 200px;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容