Сделать сетку заполнить оставшееся пространство, если столбцов меньше, чем указано - PullRequest
0 голосов
/ 24 января 2020

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

В настоящее время я использую grid-template-columns: repeat (8 , авто); который хорошо заполняет пространство 8 столбцами, но если у меня есть 6, например, он оставляет пространство справа.

*,
body,
html {
  margin: 0;
  box-sizing: border-box;
}

.card {
  width: 100%;
  height: 150px;
  min-height: 100px;
  background-color: #333333;
  border-radius: 15px;
  padding: 10px 10px;
  overflow: hidden;
  position: relative;
}

.gridWrapper {
  display: grid;
  grid-template-columns: repeat(8, auto);
  grid-gap: 5px;
  margin-bottom: 10px;
}

.gridItem {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 6px;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

label {
  font-family: Helvetica;
  font-size: 0.8em;
  color: #76a8b0;
  font-weight: 100;
}

p {
  color: #ffffff;
  font-family: Helvetica;
  font-weight: 100;
}

.cardFooter {
  display: flex;
  flex-direction: row;
  justify-content: center;
  padding: 10px 0 5px 0;
  position: absolute;
  background: #333333;
  bottom: 0;
  width: 100%;
}
<div class="card" id="card">
  <div class="gridWrapper">
    <div class="gridItem">
      <label for="title">Label</label>
      <p>ContentContentContent</p>
    </div>
    <div class="gridItem">
      <label for="title">Label</label>
      <p>Content</p>
    </div>
    <div class="gridItem">
      <label for="title">Label</label>
      <p>Content</p>
    </div>
    <div class="gridItem">
      <label for="title">Label</label>
      <p>Content</p>
    </div>
    <div class="gridItem">
      <label for="title">Label</label>
      <p>Content</p>
    </div>
    <div class="gridItem">
      <label for="title">Label</label>
      <p>Content</p>
    </div>
    <!-- <div class="gridItem">
          <label for="title">Label</label>
          <p>Content</p>
        </div>
        <div class="gridItem">
          <label for="title">Label</label>
          <p>Content</p> 
        </div> -->
  </div>
</div>

Я создал jsfiddle в https://jsfiddle.net/eh7g8Lx1/1/

Ответы [ 2 ]

1 голос
/ 24 января 2020

Замените grid-template-columns: repeat(8, auto);

строку на

grid-template-columns: repeat(auto-fit, minmax(1rem,1fr));

значение автоподбора решит вашу проблему

0 голосов
/ 27 января 2020

Мне удалось исправить это с помощью

grid-template-columns: repeat(auto-fit, 12%);
...