一、固定宽高:
1、定位 + margin-top + margin-left
.box-container{ position: relative; width: 300px; height: 300px; } .box-container .box { width: 200px; height: 100px; position: absolute; left: 50%; top: 50%; margin-top: -50px; /* 高度的一半 */ margin-left: -100px; /* 宽度的一半 */ }
设置父元素的position为相对定位,子元素绝对定位,并在 top 和 left 方向上移动父元素50%的距离。 但这个时候,是子元素的上边框和左边框距离父元素150px,整体向右下角偏了一些,所以还需要再用 margin 调整至中心位置,数值分别是高度和宽度的一半。
2、定位 + margin
.box-container{ position: relative; } .box { width: 100px; height: 100px; position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto; }
同样是使用绝对定位,但四个方向的偏移量全都为0,之后设置 margin:auto 分配剩余空间,令元素的均匀拖拽至父元素的中心位置。(如果是未知宽高,.box元素会填满整个父元素,并不能实现居中效果,如下表)
表一:.box没有设置宽高
表二:.box设置了width: 50px; height: 50px;
二、未知宽高
1、transform 方案: 存在兼容问题:
.box { position: relative; left: 50%; top: 50%; transform: translate(-50%, -50%); }
在子元素上设置,transform: translate(-50%, -50%); 用于平面的2D转换,后面的百分比以自身的宽高为参考,定位后将元素的左上角置于父级中央,之后再用 transform 进行偏移,相当于上面设置的 margin-top 和 margin-left。
注意:transform存在浏览器兼容问题,如下表。
2、flexbox 方案: 存在兼容问题
.box-container { display: -webkit-flex; display: -moz-flex; display: -ms-flex; display: -o-flex; display: flex; justify-content: center; align-items: center; }
设置父元素为 flex 弹性盒模型,并在主轴和副轴上设置居中,关于弹性盒模型的详情请点击这里。
作为新增属性,flex同样存在兼容问题,如下表: