Выровнять несколько столбцов неупорядоченного списка (UL) по горизонтали - PullRequest
0 голосов
/ 18 января 2019

У меня есть несколько неупорядоченных списков с различным количеством элементов и с заголовком столбца, в котором содержится различное количество текста.

Я использую flexbox для их горизонтального выравнивания, но я борюсь с выравниванием столбцов друг с другом.

Текущая проблема: Current Problem Желаемый результат: Desired Outcome

Редактировать. Предостережение заключается в том, что класс заголовка столбца является необязательным и может быть удален, так что элемент является просто обычным элементом списка.

Когда заголовок столбца имеетактивирован, мне нужно, чтобы заголовок столбца соответствовал высоте заголовка столбца li с наибольшим количеством текста.У меня есть flexbox, работающий для выравнивания списков по горизонтали, но столбцы не выстраиваются в линию.

Вот JsFiddle: (https://jsfiddle.net/xk04m7g1/)

.column-stack {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 30px
}

.column-stack ul {
  -ms-flex: none;
  flex: none;
  width: calc(33.333% - 10px);
}

.column-stack ul .column-header {
  font-size: 12px;
  text-transform: uppercase;
  color: #006a4d;
  font-weight: 500;
  padding-bottom: 5px;
  border-bottom: 1px solid #3a3a3a;
  display: flex;
  align-items: stretch;
  /* Default */
  justify-content: space-between;
}
<div class="column-stack">
  <ul>
    <li class="column-header">Header 1 One Line</li>
    <li>Item 1</li>
    <li>Item 2</li>
    <li>Item 3</li>
    <li>Item 4</li>
  </ul>
  <ul>
    <li class="column-header">Header 2 Many Lines of Text this is many lines of text and is the longest column wow it keeps going and going and going like the energizer rabbit</li>
    <li>Item 1</li>
    <li>Item 2</li>
    <li>Item 3</li>
    <li>Item 4</li>
  </ul>
  <ul>
    <li class="column-header">Header 3 Two Line at most on most use cases</li>
    <li>Item 1</li>
    <li>Item 2</li>
    <li>Item 3</li>
    <li>Item 4</li>
  </ul>
</div>

Я ожидаю, что заголовки столбцов неупорядоченного списка будут выровнены по центру и горизонтали независимо от того, сколько текста в этом столбце.Помогите!

Ответы [ 4 ]

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

Думая о нескольких опциях, например, таблица, сетка и т. Д., Но это может быть полезно, если вы хотите остаться с flex, но не хотите ограничиваться фиксированным количеством столбцов.

Если вы можете изменить порядок HTML-кода таким образом, чтобы заголовки находились в отдельном контейнере с отображением flex, а списки также находились в контейнере с отображением flex, что обеспечило бы одинаковую высоту всех заголовков, например:

    .column-stack {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .column-stack ul {
        flex-grow: 1;
        flex-basis: 1px;
    }

.headers {
  display:flex;
  
}
 .column-header {
        font-size: 12px;
        text-transform: uppercase;
        color: #006a4d;
        font-weight: 500;
        padding-bottom: 5px;
        border-bottom: 1px solid #3a3a3a;
        display: flex;
        align-items: stretch; /* Default */
        justify-content: space-between;
        flex-grow: 1;
        flex-basis: 1px;
        margin: 10px;
 }
<div class="headers">
  <div class="column-header">Header 1 One Line</div>
  <div class="column-header">Header 2 Many Lines of Text this is many lines of text and is the longest column wow it keeps going and going and going like the energizer rabbit</div>
  <div class="column-header">Header 3 Two Line at most on most use cases</div>
</div>

<div class="column-stack">
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
<li>Item 4</li>
</ul>
</div>

просто не забудьте добавить flex-grow: 1; и flex-basis: 1px;, чтобы ширина была такой же, как и

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

Вы можете использовать функцию, подобную этой, чтобы найти самый высокий элемент заголовка и установить остаток для этого размера.

window.onload = resizeHeaders;

function resizeHeaders()
{
  var headers = document.getElementsByClassName("column-header");
  
  var maxHeight = 0;
  for(var i = 0; i < headers.length; i++)
  {
    if(maxHeight < headers[i].offsetHeight)
      maxHeight = headers[i].offsetHeight;
  }
  
  for(var i = 0; i < headers.length; i++)
  {
    headers[i].style.height = maxHeight+"px";
  }
}
.column-stack {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 30px
}

.column-stack ul {
  -ms-flex: none;
  flex: none;
  width: calc(33.333% - 10px);
}

.column-stack ul .column-header {
  font-size: 12px;
  text-transform: uppercase;
  color: #006a4d;
  font-weight: 500;
  padding-bottom: 5px;
  border-bottom: 1px solid #3a3a3a;
  display: flex;
  align-items: stretch;
  /* Default */
  justify-content: space-between;
}
<div class="column-stack">
  <ul>
    <li class="column-header">Header 1 One Line</li>
    <li>Item 1</li>
    <li>Item 2</li>
    <li>Item 3</li>
    <li>Item 4</li>
  </ul>
  <ul>
    <li class="column-header">Header 2 Many Lines of Text this is many lines of text and is the longest column wow it keeps going and going and going like the energizer rabbit</li>
    <li>Item 1</li>
    <li>Item 2</li>
    <li>Item 3</li>
    <li>Item 4</li>
  </ul>
  <ul>
    <li class="column-header">Header 3 Two Line at most on most use cases</li>
    <li>Item 1</li>
    <li>Item 2</li>
    <li>Item 3</li>
    <li>Item 4</li>
  </ul>
</div>
0 голосов
/ 18 января 2019

Просто добавьте высоту к вашему .column-header

.column-stack ul .column-header {
height:80px;
}

и это правильно выровняется

https://jsfiddle.net/ot6qsu4w/20/

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

Если вы можете настроить разметку, я бы переместил column-header из списка. Таким образом, вы можете согнуть заголовок и список в одном родительском flexbox.

Примечание: Семантически говоря, не имеет большого смысла, что заголовок списка сам по себе является элементом списка в списке.

.column-stack {
  display: flex;
  justify-content: space-between;
}

.column {
  padding: 10px;
  flex: 1 1 33%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.column-stack .column-header {
  font-size: 12px;
  text-transform: uppercase;
  color: #006a4d;
  font-weight: 500;
  padding-bottom: 5px;
  border-bottom: 1px solid #3a3a3a;
  flex: 1;
  display: flex;
  justify-content: center;
  flex-direction: column;
  
}
<div class="column-stack">
  <div class="column">
    <h5 class="column-header">Header 1 One Line</h5>
    <ul class="column-list">
      <li>Item 1</li>
      <li>Item 2</li>
      <li>Item 3</li>
      <li>Item 4</li>
    </ul>
  </div>

  <div class="column">
    <h5 class="column-header">Header 2 Many Lines of Text this is many lines of text and is the longest column wow it keeps going and going and going like the energizer rabbit</h5>
    <ul class="column-list">
      <li>Item 1</li>
      <li>Item 2</li>
      <li>Item 3</li>
      <li>Item 4</li>
    </ul>
  </div>

  <div class="column">
    <h5 class="column-header">Header 3 Two Line at most on most use cases</h5>
    <ul class="column-list">
      <li>Item 1</li>
      <li>Item 2</li>
      <li>Item 3</li>
      <li>Item 4</li>
    </ul>
  </div>

</div>

Редактировать

Похоже, что на самом деле вы ищете скромную таблицу HTML.

th {
  font-size: 12px;
  text-transform: uppercase;
  color: #006a4d;
  font-weight: 500;
  padding-bottom: 5px;
  border-bottom: 1px solid #3a3a3a;
}

td {
  width: 33%;
}
<table>
  <thead>
    <th>Header 1 One line</th>
    <th>Header 2 Many Lines of Text this is many lines of text and is the longest column wow it keeps going and going and going like the energizer rabbit</th>
    <th>Header 3 Two Line at most on most use cases</th>
  </thead>
  <tbody>
    <tr>
      <td>Item 1</td>
      <td>Item 1</td>
      <td>Item 1</td>
    </tr>
    <tr>
      <td>Item 2</td>
      <td>Item 2</td>
      <td>Item 2</td>
    </tr>
    <tr>
      <td>Item 3</td>
      <td>Item 3</td>
      <td>Item 3</td>
    </tr>
    <tr>
      <td>Item 4</td>
      <td>Item 4</td>
      <td>Item 4</td>
    </tr>
  </tbody>
</table>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...