- PC端,1920px宽度的图片在各种宽度的屏幕始终居中显示
<section id="active_img">
<img src="" alt="">
<img src="" alt="">
<div style="display: flex;">
<a href=""><img src="" alt=""></a>
<a href=""><img src="" alt=""></a>
</div>
#active_img{
position: relative;
width: 100%;
height: 100%;
overflow: hidden;
}
#active_img>img{
position: relative;
height: auto;
display: block;
left: 50%;
margin-left: -960px;
}
#active_img div{
width:1920px; position:relative;left:50%;margin-left:-960px;"
}
<a>
标签嵌套<img>
的问题,a的高度并不是图像的高度,而是一个很奇怪的高度。- a元素下有一个匿名文本,这个文本外有一个匿名行级盒子,它有的默认vertical-align是baseline的,而且往往因为上文line-height的影响,使它有个line-height,从而使其有了高度,因为baseline对齐的原因,这个匿名盒子就会下沉,往下撑开一些距离,所以把a撑高了。
解决办法一是消除掉匿名盒子的高度,也就是给a设置line-height:0或font-size:0;
解决办法二是给两者vertical-align:top,让其top对齐,而不是baseline对齐
解决办法三是给img以display:block,让它和匿名行级盒子不在一个布局上下文中,也就不存在行级盒的对齐问题