如何将子项的高度并排填充;

时间:2019-05-13 21:07:22

标签: css css3

我正在尝试使用css和html制作一些块,例如,只有200 px的像素具有固定的高度,但是其他的则需要动态/灵活,并且需要通过其他高度进行拉伸。 C,G,H块需要是动态的,并由相对的块拉伸到最大当前高度(含内容)。在图片中,您看到块超出了区域,C,G,H块必须在绘制红线的地方处于高度;

图片我想说的 Image what i want to say

.clearFix {
  clear: both;
}


/*        Header blocks    */

.headerBlockSection {
  color: white;
  font-size: 50px;
}

.block-A {
  width: calc((100% / 4 * 3) - 10px);
  height: 200px;
  background-color: #008000;
  float: left;
  margin-right: 10px;
}

.block-B {
  width: calc(100% / 4 * 1);
  height: 200px;
  background-color: #008000;
  float: left;
}


/*        Main content sections    */

.mainContentSection {
  margin-top: 10px;
  color: white;
  display: flex;
}

.contentSection-1 {
  width: calc((100% / 4 * 1));
  float: left;
  height: auto;
}

.contentSection-2 {
  width: calc((100% / 4 * 2) - 20px);
  float: left;
  margin-left: 10px;
  margin-right: 10px;
}

.contentSection-3 {
  width: calc((100% / 4 * 1));
  float: left;
}


/*        Left    */

.block-C {
  background-color: #f8eb3a;
  height: 100%;
}


/*        Middle    */

.block-D {
  height: 150px;
  background-color: #316266;
}

.block-E {
  margin-top: 10px;
  height: 150px;
  background-color: #316266;
}

.block-G {
  margin-top: 10px;
  background-color: #316266;
  height: 100%;
}


/*
        Right
    */

.block-F {
  height: 150px;
  background-color: #801a00;
}

.block-H {
  margin-top: 10px;
  background-color: #801a00;
  height: 100%;
}


/*        Footer blocks    */

.block-I {
  margin-top: 10px;
  width: 100%;
  height: 200px;
  background-color: #9ad7ff;
}
<body>
  <header class="headerBlockSection">
    <div class="block-A">A</div>
    <div class="block-B">B</div>
    <div class="clearFix"></div>
  </header>

  <section class="mainContentSection">
    <div class="contentSection-1">
      <div class="block-C"> C </div>
    </div>
    <div class="contentSection-2">
      <div class="block-D">D</div>
      <div class="block-E">E</div>
      <div class="block-G"> G </div>
    </div>
    <div class="contentSection-3">
      <div class="block-F">F</div>
      <div class="block-H">H</div>
    </div>
    <div class="clearFix"></div>
  </section>

  <div class="block-I">I</div>

</body>

1 个答案:

答案 0 :(得分:0)

您看起来像this一样吗?

.mainContentSection {
  margin-top: 10px;
  color: white;
  display: flex;
  overflow: hidden;   /* I added this value*/
}

这是完整的代码。我还在G部分添加了一些文字以使其清楚。

.clearFix {
  clear: both;
}


/*        Header blocks    */

.headerBlockSection {
  color: white;
  font-size: 50px;
}

.block-A {
  width: calc((100% / 4 * 3) - 10px);
  height: 200px;
  background-color: #008000;
  float: left;
  margin-right: 10px;
}

.block-B {
  width: calc(100% / 4 * 1);
  height: 200px;
  background-color: #008000;
  float: left;
}


/*        Main content sections    */

.mainContentSection {
  margin-top: 10px;
  color: white;
  display: flex;
  overflow: hidden; /* I added this value*/
}

.contentSection-1 {
  width: calc((100% / 4 * 1));
  float: left;
  height: auto;
}

.contentSection-2 {
  width: calc((100% / 4 * 2) - 20px);
  float: left;
  margin-left: 10px;
  margin-right: 10px;
}

.contentSection-3 {
  width: calc((100% / 4 * 1));
  float: left;
}


/*        Left    */

.block-C {
  background-color: #f8eb3a;
  height: 100%;
}


/*        Middle    */

.block-D {
  height: 150px;
  background-color: #316266;
}

.block-E {
  margin-top: 10px;
  height: 150px;
  background-color: #316266;
}

.block-G {
  margin-top: 10px;
  background-color: #316266;
  height: 100%;
}


/*         Right     */

.block-F {
  height: 150px;
  background-color: #801a00;
}

.block-H {
  margin-top: 10px;
  background-color: #801a00;
  height: 100%;
}


/*        Footer blocks    */

.block-I {
  margin-top: 10px;
  width: 100%;
  height: 200px;
  background-color: #9ad7ff;
}
<body>
  <header class="headerBlockSection">
    <div class="block-A">A</div>
    <div class="block-B">B</div>
    <div class="clearFix"></div>
  </header>

  <section class="mainContentSection">
    <div class="contentSection-1">
      <div class="block-C"> C </div>
    </div>
    <div class="contentSection-2">
      <div class="block-D">D</div>
      <div class="block-E">E</div>
      <div class="block-G"> G <br> Lorem ipsum dolor sit amet consectetur adipisicing elit. Numquam, quas ullam ad eveniet ratione maiores fuga sapiente alias repellendus dolor sequi voluptate quaerat aliquam ut totam, perspiciatis cupiditate molestias? Tempora!
      </div>
    </div>
    <div class="contentSection-3">
      <div class="block-F">F</div>
      <div class="block-H">H</div>
    </div>
    <div class="clearFix"></div>
  </section>

  <div class="block-I">I</div>

</body>