解决方法一:
父元素设置display:table
需要居中的元素 设置 :
vertical-align:middle;
display:table-cell;
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<style type="text/css">
html,body{
width: 100%;
height: 100%;
}
#box{
width: 50%;
height: 50%;
border: 1px red solid;
text-align: center;
display:table;
}
.tab{
display:table-cell;
vertical-align:middle;
}
</style>
<body>
<div id="box">
<div class="tab">hehe</div>
</div>
</body>
</html>
解决方法二:
需要居中的元素设置(弹性布局及居中属性) :
display:flex; //弹性布局,可以应用于容器中,也可以应用于行内元素
align-items:center; //元素在该行的侧轴(纵轴)上居中放置。
justify-content:center; //元素在横轴上居中排列
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<style type="text/css">
html,body{
width: 100%;
height: 100%;
}
#box{
float: left;
width: 49%;
height: 49%;
border: 1px red solid;
text-align: center;
/*弹性布局及属性*/
display:flex;
align-items:center;
justify-content:center;
}
</style>
<body>
<div id="box">hehe</div>
<div id="box">hehe2</div>
</body>
</html>