3

I know there are similar questions about, but I have tried all of the suggestions and still cant get it working. I am using Bootstrap, and I have a section that is 100vh in height. Within this section I have two rows, the second row I needed placing at the very bottom of the section, but did not want to use absolute positioning. As such, I used the flex system.

My layout was like so

.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>

I made use of a lot of Bootstrap classes to help me achieve this layout. To demonstrate the issue, I have changed the height of the section to 900px rather than 100vh

So, if you view this JSFiddle in something like chrome, you will see that the image row sits at the bottom of the section. However, if you view it in IE11, you will see that the image row does not sit at the bottom of the section.

Is there any way to make this layout work within IE11?

Michael Benjamin
  • 346,931
  • 104
  • 581
  • 701
katie hudson
  • 2,765
  • 13
  • 50
  • 93
  • 1
    I'm running it in IE and Chrome with the same effect https://www.screencast.com/t/IK6mgEbk See the screenshot – LOTUSMS Nov 06 '17 at 12:53
  • From the looks of your screenshot, you are displaying it in tablet view. If you increase the width of the browser, the images should be on the same row, not stacked. Thanks – katie hudson Nov 06 '17 at 13:47
  • You should specify this in your question by the way, but either way, here is a full screen screenshot in IE https://www.screencast.com/t/UZblTMhTB6 – LOTUSMS Nov 06 '17 at 13:54
  • Thats definitely not displaying correctly for you. The two images should be next to each other, not stacked. – katie hudson Nov 06 '17 at 17:57

3 Answers3

5

You can do these 2 things to make it render the same cross browsers:

  • IE has a min-height bug when using flex column direction, adding display: flex to its parent (section) solves that

  • IE also have some issues when it comes to auto margins, so instead of margin-top: auto on the .col-md-4 item, use align-items: flex-end on the parent (row d-flex fHeight)

Updated fiddle

Stack snippet

.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://i.stack.imgur.com/V5BcV.png" 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>
Asons
  • 84,923
  • 12
  • 110
  • 165
0

I was using Bootstrap 4 class .d-flex with min-height: 350px; which have no-spacing/height issue for container in IE11. Fixed by adding height to the flex container.

Try adding height

height: 350px;
Deepak Rajpal
  • 811
  • 1
  • 8
  • 11
0

In addition to this. I would recommend to use your own .d-flex class.

I've implemented this sass script: https://gist.github.com/richardtorres314/26b18e12958ba418bb37993fdcbfc1bd

.d-flex-new {
  @include flexbox();
  width: 100%;
}

This in combination with the two options from @Ason

Lance
  • 61
  • 7