IE 11:Flex增长父母问题



我有这样的代码:

https://plnkr.co/edit/zaezfaoco0zcsqsq2or4lp?p=preview

但这在IE中不起作用,直到添加高度:0(对父元素是一个非常糟糕的主意)

  <body>
    <div class="container">
      <div class="container-item container-item-1"></div>
      <div class="container-item container-item-2"></div>
      <div class="container-item container-item-3"></div>
    </div>
  </body>
body, html {
  min-height: 100%;
  height: 100%;
}
.container {
  width: 100%;
  min-height: calc(100% - 80px);
  margin: 30px;
  padding: 20px;
  border: 1px solid gray;
  border-radius: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.container-item {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  content: "someText";
  border-bottom: 1px solid #cecece;
}
.container-item-1 {
  background-color: red;
}
.container-item-2 {
  background-color: orange;
}
.container-item-3 {
  background-color: green;
}

Chrome和ff中的一切都很好(我的父母应该扩大以适合父母)

重要!

我需要一个灵活的解决方案,我的代码可以在身体和内容divs之间具有很多嵌套的div(不是恒定值)。

例如:

<body>
  <div>
    <div>
      <div class="container">
        <div class="container-item container-item-1"></div>
        <div class="container-item container-item-2"></div>
        <div class="container-item container-item-3"></div>
      </div>
    </div>
  </div>
</body>

<body>
  <div>
    <h3>text</h3>
      <div class="container">
        <div class="container-item container-item-1"></div>
        <div class="container-item container-item-2"></div>
        <div class="container-item container-item-3"></div>
      </div>
  </div>
</body>

如果您在container之前有未知数或嵌套的标记,则可以在其中添加额外的包装器(此处 inner),以克服IE的 min-min-height bug。

小提琴样品1-小提琴样品2

堆栈片段样本1

html, body {
  margin: 0;
}
.container {
  display: flex;
}
.container .inner {
  width: 100%;
  min-height: calc(100vh - 100px);
  margin: 30px;
  padding: 20px;
  border: 1px solid gray;
  border-radius: 16px;
  display: flex;
  flex-direction: column;
}
.container-item {
  flex-grow: 1;
  border: 1px solid #cecece;
}
.container-item-1 {
  background-color: red;
}
.container-item-2 {
  background-color: orange;
}
.container-item-3 {
  background-color: green;
}
<div>
  <h3>text</h3>
  <div class="container">
    <div class="inner">
      <div class="container-item container-item-1">
      </div>
      <div class="container-item container-item-2">
      </div>
      <div class="container-item container-item-3">
      </div>
    </div>
  </div>
</div>

堆栈摘要样本2

html, body {
  margin: 0;
}
.container {
  display: flex;
}
.container .inner {
  width: 100%;
  min-height: calc(100vh - 100px);
  margin: 30px;
  padding: 20px;
  border: 1px solid gray;
  border-radius: 16px;
  display: flex;
  flex-direction: column;
}
.container-item {
  flex-grow: 1;
  border: 1px solid #cecece;
}
.container-item-1 {
  background-color: red;
}
.container-item-2 {
  background-color: orange;
}
.container-item-3 {
  background-color: green;
}
<div>
  <div>
    <div class="container">
      <div class="inner">
        <div class="container-item container-item-1">
        </div>
        <div class="container-item container-item-2">
        </div>
        <div class="container-item container-item-3">
        </div>
      </div>
    </div>
  </div>
</div>

最新更新