table-cell 水平垂直居中的问题

3,160 阅读1分钟

背景: 最近在看一些面试题,里面有关于水平垂直居中的方案,平常都是用flex,很少用到table-cell 再复习一下

如果真的要实现垂直居中,只有table-cell 是不够的

  1. table-cell 需要设置宽高
  2. table-cell 的子元素需要是 display: inline-block; 不能是块级元素
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        #id1 {
            width: 100px;
            height: 100px;
            background: blue;
            display: table-cell;
            vertical-align: middle;
            text-align: center;
        }
        #id2 {
            background: red;
            display: inline-block;
            width: 50%;
            height: 50%;
        }
    </style>
</head>
<body>
    <div id="id1">
        <div id="id2">
            测试一下
        </div>
    </div>
</body>
</html>