我正在尝试创建一个产品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:table
和table-cell
可能是我一直在以某种错误的方式使用它们......请帮助我:(
答案 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;
}
演示
如果你知道容器的高度,你也可以将line-height
设置为相同的值,而不是使用div.height
。