2017-04-10 65 views
1

我在水平线上有各种图像。有些图片大小不同,所以我希望所有图片都相对于它们所包含的div居中,所以看起来更好。我希望能够实现这个目标,而不是目前设置的方式,即添加顶部边距。如何在div中间放置不同尺寸的图像

有没有办法在css中自动执行此操作,以便如果图像发生更改,它们仍会相对于包含div而居中?

https://jsfiddle.net/0aqavqtL/

<div class="row" style="text-align: center; margin: 30px 0; width: 100%;"> 
<div class="col-xs-12 col-sm-4 col-md-2" style="margin: 15px 0; text-align: center; display: inline-block; vertical-align: middle;"> 
<a href="http://example.com/" target="_blank"><img src=""></a> 
</div> 
<div class="col-xs-12 col-sm-4 col-md-2" style="margin: 15px 0; text-align: center; display: inline-block; vertical-align: middle;"> 
<a href="http://example.com/" target="_blank"> 
<img src=""></a> 
</div> 
<div class="col-xs-12 col-sm-4 col-md-2" style="margin: 15px 0; text-align: center; display: inline-block; vertical-align: middle;"> 
<a href="http://example.com" target="_blank"> 
<img src="https://upload.wikimedia.org/wikipedia/en/e/ef/Dots_video_game_cover.png"></a> 
</div> 
<div class="col-xs-12 col-sm-4 col-md-2" style="margin: 15px 0; text-align: center; display: inline-block; vertical-align: middle;"> 
<a href="http://example.com" target="_blank"> 
<img src=""></a> 
</div> 
</div> 

回答

0

使用display: flex父母与justify-content: centeralign-items: center将水平和垂直居中的行中的孩子。

如果你想行换到下一行,当没有足够的空间的cols显示并排侧,适用于flex-wrap: wrap.row.centered

.row.centered { 
 
    height: 100vh; 
 
    display: flex; 
 
    align-items: center; 
 
    justify-content: center; 
 
}
<div class="row centered" > 
 
    <div class="col-xs-12 col-sm-4 col-md-2" style=""> 
 
    <a href="http://example.com/" target="_blank"><img src=""></a> 
 
    </div> 
 
    <div class="col-xs-12 col-sm-4 col-md-2" style=""> 
 
    <a href="http://example.com/" target="_blank"><img src=""></a> 
 
    </div> 
 
    <div class="col-xs-12 col-sm-4 col-md-2" style=""> 
 
    <a href="http://example.com" target="_blank"><img src="https://upload.wikimedia.org/wikipedia/en/e/ef/Dots_video_game_cover.png"></a> 
 
    </div> 
 
    <div class="col-xs-12 col-sm-4 col-md-2" style=""> 
 
    <a href="http://example.com" target="_blank"><img src=""></a> 
 
    </div> 
 
</div>

+0

这是完美的!谢谢! – penmas

+0

你知道我将添加什么规范来允许这种对齐转移到Mozilla和Safari吗?我注意到它没有在那里工作。 – penmas

+0

@penmas应该在最新版本中正常工作。我刚刚检查了FF和safari,看起来像预期的。如果您使用的是旧版本,则可能需要使用浏览器前缀。我相信这只是'display:-webkit-flex','-webkit-align-items:center'和'-webkit-justify-content:center'(用'moz'替换'webkit'为ff) –

0

您可以使用Flexbox的,就像这样:

.container { 
 
display: flex; 
 
align-items: center; 
 
background-color: grey; 
 
flex-wrap: wrap; 
 
} 
 

 
.item { 
 
flex-basis: 400px; 
 
flex-grow: 1; 
 
margin: 10px; 
 
height: 200px; 
 
background-color: red; 
 

 
} 
 

 
.item1 { 
 
height: 100px; 
 
}
<div class="container"> 
 
<div class="item item1"></div> 
 
<div class="item item2"></div> 
 
<div class="item item13"></div> 
 
</div>

你可以看到你有一个容器,用flex一个display属性,三个不同高度的弹性物品。

通过将容器的align-items属性(影响垂直对齐)设置为center,您将将所有弹性项目居中,无论其高度如何。

这是一个非常“灵活”的设计,因为它不依赖于元素的大小或数量。

我希望这会有所帮助。

+0

这看起来不错,但你如何推荐配置移动视图? – penmas

+0

@penmas我更新了我的代码来演示如何做到这一点。 正如您所看到的,我更改了flex-basis属性的flex项目的width属性,该属性设置了元素的初始宽度。我将该属性设置为400px。 然后,我为每个柔性项目添加了1的flex-grow属性,这意味着它们将均等增长以填充容器中的任何剩余宽度。 最后,我设置容器的flex-wrap属性进行换行。这意味着如果没有足够的空间让项目占用他们的宽度,他们会换到下一行 – Larpee

+0

@penmas如果有足够的空间,更改该代码片段将允许您为项目分配初始宽度,并告诉他们如果没有包装到下一行。 这使得一个良好的响应式设计 – Larpee

相关问题