1、兼容性不错的主流css绝对定位居中的用法:
.conter{
width:600px;height:400px;
position:absolute;left:50%;top:50%;
margin-top:-200px;/*高度的一半*/
margin-left:-300px;/*宽度的一半*/
}
注意:这种方法有一个很明显的不足,就是需要提前知道元素的尺寸。否则margin负值的调整无法精确。此时,往往要借助JS获得。
2、css3的出现,使得有了更好的解决方法,就是使用transform代替margin.transform中translate偏移的百分比值是相对于自身大小的,可以这样实现css绝对定位居中:
.conter{
width:600px;height:400px;
position:absolute;left:50%;top:50%;
transform:translate(-50%,-50%);/*50%为自身尺寸的一半*/
}
3、margin:auto实现绝对定位元素的居中(上下左右均0位置定位;margin:auto)
.conter{
width:600px;height:400px;
position:absolute;left:0;top:0;right:0;bottom:0;
margin:auto;/*有了这个就自动居中了*/
}
4、使用css3盒模型:flex布局实现css绝对定位居中。这种情况是在不考虑低版本浏览器的情况下可以使用。