【问题标题】:image is not resizing in a flexbox layout图像未在 flexbox 布局中调整大小
【发布时间】: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 &gt; a &gt; img 中的图像由于相对 90% 的宽度属性而具有响应性,这使其适应父级。 “需要弯曲的图像仍保持其原始尺寸”是什么意思?当窗口变小时它会调整大小。
  • @MichaelCoker 它仅在第二个 outerDiv 包装后才调整大小。我希望它缩小以腾出空间,并在它有额外空间时增长。
  • 为什么不直接从section 中删除flex-wrap: wrap;,这样第二个outerDiv 就不会换行?
  • @MichaelCoker 在真实页面上还有其他类似的 div,如果它们缩小,它会在很多宽度上更好地工作。

标签: html css flexbox responsive-images


【解决方案1】:

弹性项目的初始设置是min-width: auto。这意味着默认情况下,弹性项目不能缩小到其内容的大小以下。

在这种情况下,section 元素是主要的弹性容器。

弹性项目是.outerDiv

因为这些弹性项目包含图像,所以它们不能缩小到图像大小以下。要克服这个问题,请使用 min-width: 0 覆盖默认值。

revised codepen

好的,现在项目可以缩小到内容之外,但图像仍然不灵活。

您可以通过以下方式解决此问题:

img { width: 100%; height: auto; }

revised codepen

这里有更多信息:Why doesn't flex item shrink past content size?

【讨论】:

  • 我将不得不在早上更仔细地阅读。我想要缩小的图像在名为 .imgResize 的类中确实具有 90% 和自动。我需要另一个来保持它的大小,所以我就这样做了。修改后的 codepen 中的行为仍然存在麻烦的行为 - 第一个 div 集直到第二个包裹后才会缩小。
  • 不清楚您到底想要什么,但希望弹性项目最小尺寸的概念和链接参考能够引导您找到解决方案。否则,请随时在此处发布更多详细信息。
  • 我最终缩小了图像以回避问题。现在要折腾太多了。不过这里的材料很有帮助。
  • 对于flex-direction: column,我必须使用min-height: auto。非常感谢,这救了我:)
猜你喜欢
  • 1970-01-01
  • 2016-05-28
  • 2021-10-02
  • 1970-01-01
  • 2016-08-06
  • 2014-02-01
  • 2018-12-22
  • 1970-01-01
  • 2018-04-30
相关资源
最近更新 更多