第一种 借助inline-block的特点
#d1{
display:inline-block
width:500px
height:500px
border:1px solid red
text-align:center
}
#d1:after{
content:""
display:inline-block
height:100%
vertical-align:middle
background:#000
}
#d2{
display:inline-block
width:200px
height:200px
border:1px solid red
vertical-align:middle
}
<div id="d1">
<div id="d2"></div>
</div>
第二种 利用css的transform 好用但是兼容性不好,IE10+以及其他现代浏览器才支持(手机开发可忽略)
.box{width:300pxheight:300pxborder:1px solid redposition:relative}
.content{
position:absolute
width:100px
height:100px
border:1px solid red
margin:0 auto
top:50%left:50%
/* transform:translateY(-50%)仅垂直居中*/
/* transform:translateX(-50%)仅水平居中*/
transform: translate(-50%, -50%)
/*
若父容器下只有一个元素,且父元素设置了高度,则只需要使用相对定位即可
父元素{
height:xxx
}
.子元素 {
position: relative
top: 50%
transform: translateY(-50%)
}
*/
}
<div class="box">
<div class="content"></div>
</div>
第三种:绝对定位之后的偏移
.box{
border:1px solid red
width:300pxheight:300pxposition:relative
}
.content{
border:1px solid red
width: 200pxheight: 200px
position: absoluteleft: 50%top: 50%
margin-top: -100px /* 高度的一半 */
margin-left: -100px /* 宽度的一半 */
}
<div class="box">
<div class="content"></div>
</div>
第四种:定位之后的margin: auto
.box{
border:1px solid red
width:300pxheight:300pxposition:relative
}
.content{
width: 200px
height: 200px
position: absolute
left: 0
top: 0
right: 0
bottom: 0
margin: auto
border:1px solid red
}
<div class="box">
<div class="content"></div>
</div>
第五种 flex布局
<div style="display:flexdisplay: -webkit-flexjustify-content:centeralign-items:centerwidth: 300pxheight: 300pxborder:1px solid red">
<div style="width: 200pxheight: 200pxborder:1px solid red"></div>
</div>
第六种利用display:table-cell的vertical-align属性 子元素加上“display:inline-block”可水平居中
<div style="display:table-cellvertical-align:middletext-align:centerwidth:300pxheight:300pxborder:1px solid red">
<div style="border:1px solid redwidth:200pxheight:200pxdisplay:inline-block"></div>
</div>
第七种 使用css3中的display:-webkit-box的用法这种方法还没有得到浏览器的普遍支持,如有兴趣,自行学习
您好,你要求的是指定css3盒子布局的垂直居中1.首先是要使盒子为display:box | -webkit-box| -moz-box
2.设置元素的box-pack和box-align即可,这两个属性当前只有webkit和moz支持。
3.box-pack控制的是水平的左和右,取值有:start(居左),center(居中),end(居右)。
4.box-align的取值有:start(居上),center(居中),end(居下)。
如果我们要设置垂直居中的话只需要将这两个属性的值都设置为center即可