【发布时间】:2017-06-06 02:11:42
【问题描述】:
我尝试遵循this answer 中的建议,如CodePen 所示,但需要弯曲的图像仍保持其原始尺寸,除非屏幕太窄以至于单独在一行中。
在类似情况下,真实页面中还有另一组 div - 如果侧面 div 缩小,它将有助于页面在更大的宽度范围内工作。
包裹它的 div 上面有 flex: auto; 和 img {width: 90%; height: auto;} 用于其中的任何图像,该 div 的父级有 style="flex: 0 1 250px;" 。
这是它的CodePen。
我想这是一个简单的错误,如果不是我想我会将图像作为它当前所在的 div 的背景,并在其上设置background-size: 100% auto;。
section {
padding: 15px;
display: flex;
flex-wrap: wrap;
margin-top: 3vw;
margin-left: 6vw;
}
.outerDiv {
background-color: rgba(50, 50, 0, 0.5);
}
.innerDiv {
background-color: rgba(10, 10, 10, 0.6);
display: flex;
flex-flow: column nowrap;
align-items: flex-end;
margin: 15px;
}
.innerDiv p {
padding: 6px 18px 0 15px;
}
.imgResize {
flex: auto;
align-self: center;
padding: 15px;
}
.imgResize img {
width: 90%;
height: auto;
}
<section>
<div class="outerDiv">
<div class="innerDiv" style="flex: 0 1 250px;">
<h2>The Rocket Equation</h2>
<p>Mass ratio:</p>
<div class="imgResize">
<a href="rotovator.html">
<img src="http://www.moonwards.com/img/animatedRotovatorLink.png">
</a>
</div>
</div>
</div>
<div class="outerDiv">
<div class="innerDiv">
<h2>Suborbital Hop</h2>
<img src="http://www.moonwards.com/img/mapmini.jpg" width="512" height="256">
<canvas id="subOrbitalCanvas" width="512" height="256"></canvas>
</div>
</div>
</section>
【问题讨论】:
-
目前还不清楚到底是什么问题。
.imgResize > a > img中的图像由于相对 90% 的宽度属性而具有响应性,这使其适应父级。 “需要弯曲的图像仍保持其原始尺寸”是什么意思?当窗口变小时它会调整大小。 -
@MichaelCoker 它仅在第二个 outerDiv 包装后才调整大小。我希望它缩小以腾出空间,并在它有额外空间时增长。
-
为什么不直接从
section中删除flex-wrap: wrap;,这样第二个outerDiv 就不会换行? -
@MichaelCoker 在真实页面上还有其他类似的 div,如果它们缩小,它会在很多宽度上更好地工作。
标签: html css flexbox responsive-images