即11:flex增长父问题

时间:2017-09-19 13:06:09

标签: css css3 flexbox internet-explorer-11

我有这样的代码:

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

但是这还没有工作,直到我添加高度: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中一切正常 (我的父母应该扩大到适合父母)

重要!

我需要一个灵活的解决方案,我的代码可以在正文和内容div之间有很多嵌套的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>

1 个答案:

答案 0 :(得分:0)

如果你在container之前有一个未知或嵌套的标记,你可以在其中添加一个额外的包装(这里是inner),以克服IE的 min-height 错误

Fiddle sample 1 - Fiddle sample 2

Stack snippet sample 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>

Stack snippet sample 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>