如何在固定高度div中垂直居中可变高度的div

时间:2013-03-04 16:01:36

标签: html css css3

我正在尝试创建一个产品Image div,我已经尝试了几乎所有东西,仍然无法解决一个小问题,所有我想将我的图像垂直居中在一个固定高度的盒子里,图像的大小会有所不同新产品形象。 这是我的代码 HTML:

<div class="main-pic">
 <ul>
     <li><img src="images/extra/laptop.jpg"></li>
     <li><img src="images/extra/laptop1.jpg"></li>
     <li><img src="images/extra/laptop2.jpg"></li>
     <li><img src="images/extra/laptop3.jpg"></li>
     <li><img src="images/extra/laptop4.jpg"></li>
     <li><img src="images/extra/laptop5.jpg"></li>
 </ul>
</div>

CSS:

.main-pic{width:430px;height:430px;border:1px solid black;margin:20px auto;display:block;float:none;overflow:hidden;}
.main-pic ul{width:10000px;}
.main-pic ul li{width:430px;height:430px;float:none;display:block;margin:-25% auto auto;position:relative;top:50%;}
.main-pic ul li img{max-width: 400px;height:auto;max-height: 400px;width: auto;}

仅供参考我已尝试verical-align:middle; display:tabletable-cell 可能是我一直在以某种错误的方式使用它们......请帮助我:(

1 个答案:

答案 0 :(得分:0)

要将固定高度父元素中的元素垂直居中,请设置vertical-align: middle。添加一个显示为inline-block的其他元素,其中width为全高。

示例HTML:

<div class="container">
    <div class="height"></div>
    <img ...>
    <img ...>
</div>

示例CSS:

.container {
    height: 300px;
}
.height {
    display: inline-block;
    height: 100%;
    vertical-align: middle;
    width: 0;
}
.container > img {
    vertical-align: middle;
}

JS Bin

演示

如果你知道容器的高度,你也可以将line-height设置为相同的值,而不是使用div.height