html 如下:
<div id="box">
<div id="x"></div>
</div>
方法一:父相自绝后,子分部向左向上移动本身宽度和高度的一半
#box{
width: 400px;
height: 400px;
background: red;
position: relative;
}
#x{
width: 200px;
height: 200px;
background: yellow;
position: absolute;
left: 50%;
top: 50%;
margin-left: -100px;
margin-top: -100px;
}
方法二:父向子绝,子元素所有定位为0,margin设置auto自适应。
#box{
width: 400px;
height: 400px;
border: 1px solid saddlebrown;
position: relative;
}
#x{
width: 200px;
height: 200px;
border: 1px solid rgb(65, 131, 39);
position: absolute;
left: 0;
top: 0;
right: 0;
bottom: 0;
margin: auto;
}
方法二:父元素设置成弹性盒,子元素横向居中,纵向居中
/* #box{
width: 400px;
height: 400px;
border: 1px solid saddlebrown;
display: flex;
justify-content: center;
align-items: center;
}
#x{
width: 200px;
height: 200px;
border: 1px solid rgb(65, 131, 39);
} */