Как равномерно распределить столбцы с помощью FlexBox? - PullRequest
0 голосов
/ 11 января 2019

У нас есть набор результатов, которые должны отображаться в трех столбцах. Используя Flexbox, мы смогли получить большую часть того, что хотели достичь (т.е. все имеют одинаковую высоту, правильно выровнены вверху (см. flex__top, и правильно выровнены внизу (см. flex__bottom). *) 1004 *

Однако мы столкнулись с проблемой, когда один из элементов flex__bottom имеет высоту, отличную от других, выравнивание отключено.

Как выровнять все столбцы, чтобы они имели одинаковую высоту, при этом сечение flex__bottom начинается в одинаковых позициях?

Цель

  1. Убедитесь, что все столбцы имеют одинаковую высоту
  2. Для каждого элемента внутри flex__bottom должно быть border-top, которое выравнивается со всеми остальными.

Выпуск

current issue flexbox

Желаемый выход desired output flexbox

Кодовая ручка доступна здесь на случай, если ее трудно скопировать во встроенном фрагменте кода

/* Columns */

@media screen and (min-width: 320px) {
  .col-m-12 {
    width: 100%;
    padding: 16px;
    display: flex;
    justify-content: center;
    align-items: stretch;
  }
}

@media screen and (min-width: 768px) {
  .col-t-4 {
    width: calc(33% - 48px);
  }
}


/* Flex */

.flex__wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  flex-direction: row;
  flex: 0 1 auto;
}

.flex__link {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  flex-direction: column;
  background-color: #eee;
}

.flex__top {
  padding: 16px;
}

.flex__bottom {
  border-top: 1px solid;
}


/* Image */

img {
  height: auto;
  display: block;
  width: 100%;
}


/* Lists */

ul {
  list-style: none;
}

ul>li {
  display: inline-flex;
  border: 1px solid;
  margin: 4px;
  padding: 4px;
}


/* Link */

a {
  text-decoration: none;
  color: #000;
}
<div class="flex__wrapper">
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/arch" class="flex__img">
        <h2 class="flex__h2">Check back tomorrow;</h2>
        <p>I will see if the book has arrived.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/nature" class="flex__img">
        <h2 class="flex__h2">I am happy</h2>
        <p>I am never at home on Sundays.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
          <li>Progressively matrix</li>
          <li>Uniquely build extensible</li>
          <li>seamless customer</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/people" class="flex__img">
        <h2 class="flex__h2">Malls are great places to shop</h2>
        <p>I can find everything I need under one roof.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>maximizing</li>
          <li>Monotonectally whiteboard</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/tech" class="flex__img">
        <h2 class="flex__h2">I want to buy</h2>
        <p>but know it won’t suit me.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
          <li>task error-free</li>
          <li>Energistically</li>
          <li>practices</li>
          <li>ethical methodologies</li>
          <li>task error-free</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/animals" class="flex__img">
        <h2 class="flex__h2">Last Friday in three week</h2>
        <p>Blue worm shake hands with a legless lizard.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
          <li>incubate</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/animals/grayscale" class="flex__img">
        <h2 class="flex__h2">She advised</h2>
        <p>him to come back at once.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
          <li>Seamlessly</li>
          <li>build excellent</li>
        </ul>
      </div>
    </a>
  </div>
</div>

Ответы [ 2 ]

0 голосов
/ 11 января 2019

Чтобы достичь ожидаемого результата, установите высоту для flex__bottom

Проблема: высота flex__bottom не указана, а дочерние элементы не четные, высота по умолчанию: auto будет регулировать высоту в соответствии с элементами flex__bottom

.flex__bottom {
    border-top: 1px solid;
    height: 100px;
}

https://codepen.io/nagasai/pen/LMgxLg

0 голосов
/ 11 января 2019

Если вы можете ограничить объем содержимого в заголовке и описании элемента, вы можете добавить минимальную высоту к .flex-top.

/* Columns */

@media screen and (min-width: 320px) {
  .col-m-12 {
    width: 100%;
    padding: 16px;
    display: flex;
    justify-content: center;
    align-items: stretch;
  }
}

@media screen and (min-width: 768px) {
  .col-t-4 {
    width: calc(33% - 48px);
  }
}


/* Flex */

.flex__wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  flex-direction: row;
  flex: 0 1 auto;
}

.flex__link {
  display: flex;
  flex-direction: column;
  background-color: #eee;
}

.flex__top {
  padding: 0 16px;
  min-height: 350px;
}

.flex__bottom {
  border-top: 1px solid;
}


/* Image */

img {
  height: auto;
  display: block;
  width: 100%;
}


/* Lists */

ul {
  list-style: none;
}

ul>li {
  display: inline-flex;
  border: 1px solid;
  margin: 4px;
  padding: 4px;
}


/* Link */

a {
  text-decoration: none;
  color: #000;
}
<div class="flex__wrapper">
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/arch" class="flex__img">
        <h2 class="flex__h2">Check back tomorrow;</h2>
        <p>I will see if the book has arrived.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/nature" class="flex__img">
        <h2 class="flex__h2">I am happy</h2>
        <p>I am never at home on Sundays.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
          <li>Progressively matrix</li>
          <li>Uniquely build extensible</li>
          <li>seamless customer</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/people" class="flex__img">
        <h2 class="flex__h2">Malls are great places to shop</h2>
        <p>I can find everything I need under one roof.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>maximizing</li>
          <li>Monotonectally whiteboard</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/tech" class="flex__img">
        <h2 class="flex__h2">I want to buy</h2>
        <p>but know it won’t suit me.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
          <li>task error-free</li>
          <li>Energistically</li>
          <li>practices</li>
          <li>ethical methodologies</li>
          <li>task error-free</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/animals" class="flex__img">
        <h2 class="flex__h2">Last Friday in three week</h2>
        <p>Blue worm shake hands with a legless lizard.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
          <li>incubate</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="col-m-12 col-t-4">
    <a class="flex__link" href="#">
      <div class="flex__top">
        <img src="https://placeimg.com/640/480/animals/grayscale" class="flex__img">
        <h2 class="flex__h2">She advised</h2>
        <p>him to come back at once.</p>
      </div>
      <div class="flex__bottom">
        <ul>
          <li>Learn More</li>
          <li>Seamlessly</li>
          <li>build excellent</li>
        </ul>
      </div>
    </a>
  </div>
</div>

Однако, возможно, сетка - лучший вариант для этого макета

@media screen and (min-width: 640px) {
  .grid__wrapper {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 10px;
  }
}

.grid__item {
  background: #ccc;
  padding: 10px;
  margin-bottom: 10px;
}

@media screen and (min-width: 640px) {
  .grid__item {
    margin-bottom: 0;
  }
}

@media screen and (min-width: 640px) {
  .grid__link {
    height: 100%;
    display: grid;
    grid-auto-rows: 1fr;
  }
}

.item__bottom {
  border-top: 1px solid;
}

img {
  height: auto;
  display: block;
  width: 100%;
}

ul {
  list-style: none;
}

ul>li {
  display: inline-flex;
  border: 1px solid;
  margin: 4px;
  padding: 4px;
}

a {
  text-decoration: none;
  color: #000;
}
<div class="grid__wrapper">
  <div class="grid__item">
    <a class="grid__link" href="#">
      <div>
        <img src="https://placeimg.com/640/480/arch" class="flex__img">
        <h2>Check back tomorrow;</h2>
        <p>I will see if the book has arrived.</p>
      </div>
      <div class="item__bottom">
        <ul>
          <li>Learn More</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="grid__item">
    <a class="grid__link" href="#">
      <div>
        <img src="https://placeimg.com/640/480/nature" class="flex__img">
        <h2>I am happy</h2>
        <p>I am never at home on Sundays.</p>
      </div>
      <div class="item__bottom">
        <ul>
          <li>Learn More</li>
          <li>Progressively matrix</li>
          <li>Uniquely build extensible</li>
          <li>seamless customer</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="grid__item">
    <a class="grid__link" href="#">
      <div>
        <img src="https://placeimg.com/640/480/people" class="flex__img">
        <h2>Malls are great places to shop</h2>
        <p>I can find everything I need under one roof.</p>
      </div>
      <div class="item__bottom">
        <ul>
          <li>maximizing</li>
          <li>Monotonectally whiteboard</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="grid__item">
    <a class="grid__link" href="#">
      <div>
        <img src="https://placeimg.com/640/480/tech" class="flex__img">
        <h2>I want to buy</h2>
        <p>but know it won’t suit me.</p>
      </div>
      <div class="item__bottom">
        <ul>
          <li>Learn More</li>
          <li>task error-free</li>
          <li>Energistically</li>
          <li>practices</li>
          <li>ethical methodologies</li>
          <li>task error-free</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="grid__item">
    <a class="grid__link" href="#">
      <div>
        <img src="https://placeimg.com/640/480/animals" class="flex__img">
        <h2>Last Friday in three week</h2>
        <p>Blue worm shake hands with a legless lizard. Blue worm shake hands with a legless lizard. Blue worm shake hands with a legless lizard. Blue worm shake hands with a legless lizard. </p>
      </div>
      <div class="item__bottom">
        <ul>
          <li>Learn More</li>
          <li>incubate</li>
        </ul>
      </div>
    </a>
  </div>
  <div class="grid__item">
    <a class="grid__link" href="#">
      <div>
        <img src="https://placeimg.com/640/480/animals/grayscale" class="flex__img">
        <h2>She advised</h2>
        <p>him to come back at once.</p>
      </div>
      <div class="item__bottom">
        <ul>
          <li>Learn More</li>
          <li>Seamlessly</li>
          <li>build excellent</li>
        </ul>
      </div>
    </a>
  </div>
</div>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...