在IE11中使用Flexbox布局

3
我知道有类似的问题,但我已经尝试了所有建议,仍然无法使其正常工作。我正在使用Bootstrap,并且我有一个高度为100vh的部分。在此部分中,我有两行,第二行需要放置在部分的底部,但不想使用绝对定位。因此,我使用了弹性布局系统。
我的布局如下:

.mn120 {
  min-height: 120px;
}

img {
  max-width: 40%;
}

.mh100vh {
  min-height: 900px;
}

.col-md-4 {
  margin-top: auto;
}
<section id="someSection" class="section">
  <div class="container d-flex flex-column justify-content-between fHeight mh100vh">
 <div class="row">
   <div class="col-md-8 offset-2">
  <h2 class="section-title">Header Text</h2>
  <p class="section-subtitle">
    Some Text
  </p>
   </div>
 </div>
 <div class="row d-flex fHeight">
   <div class="col-md-4">
  <img class="btmImg" src="" alt="" />
   </div>
   <div class="col-md-8">
  <img class="btmImg" src="http://www.atfund.gatech.edu/sites/default/files/images/verticalplaceholderimage-440x680.png" alt="" />
   </div>
 </div>
  </div>
</section>

我使用了许多Bootstrap类来帮助我实现这个布局。为了演示问题,我将部分的高度更改为900px而不是100vh。
因此,如果您在Chrome等浏览器中查看JSFiddle,则会发现图像行位于该部分底部。但是,如果您在IE11中查看它,则会发现图像行不在该部分底部。
有没有办法使此布局在IE11中工作?

1
我在IE和Chrome中运行它,效果相同 https://www.screencast.com/t/IK6mgEbk 请参阅截屏 - LOTUSMS
从你的截图来看,你正在以平板电脑视图显示它。如果你增加浏览器的宽度,图片应该在同一行上,而不是堆叠在一起。谢谢。 - katie hudson
顺便说一下,你应该在问题中指明这一点,但不管怎样,这里是IE浏览器的全屏截图:https://www.screencast.com/t/UZblTMhTB6 - LOTUSMS
这肯定对你的显示有问题。两个图像应该并排而不是叠在一起。 - katie hudson
3个回答

5
你可以做这两件事情来使其在各个浏览器上呈现相同的效果:
  • 使用flex column方向时,IE存在min-height bug问题,将display: flex添加到其父级元素(section)即可解决。

  • 对于.col-md-4项目,IE在自动边距方面也存在一些问题,因此在父级元素(row d-flex fHeight)上使用align-items: flex-end代替margin-top: auto

更新的fiddle

堆栈片段

.section {
  display: flex;               /*  added  */
}

.row.d-flex.fHeight {
  align-items: flex-end;       /*  added  */
}

.mn120 {
  min-height: 120px;
}

img {
  max-width: 40%;
}

.mh100vh {
  min-height: 900px;
}

/*
.col-md-4 {
  margin-top:auto;
}
*/
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" rel="stylesheet"/>

<section id="someSection" class="section">
  <div class="container d-flex flex-column justify-content-between fHeight mh100vh">
    <div class="row">
      <div class="col-md-8 offset-2">
        <h2 class="section-title">Header Text</h2>
        <p class="section-subtitle">
          Some Text
        </p>
      </div>
    </div>
    <div class="row d-flex fHeight">
      <div class="col-md-4">
        <img class="btmImg" src="https://istack.dev59.com/V5BcV.webp" alt="" />
      </div>
      <div class="col-md-8">
        <img class="btmImg" src="http://www.atfund.gatech.edu/sites/default/files/images/verticalplaceholderimage-440x680.png" alt="" />
      </div>
    </div>
  </div>
</section>


0

0
我在使用Bootstrap 4类.d-flexmin-height: 350px;,在IE11的容器上没有间距/高度问题。通过为flex容器添加高度进行修复。 尝试添加高度
height: 350px;

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接