Как мне исправить проблему с выравниваемым содержимым в CSS flexbox? Пространство между не работает должным образом - PullRequest
0 голосов
/ 07 апреля 2020

РЕДАКТИРОВАТЬ: Оказывается, мой код работает. Я просто использовал компьютер с меньшим экраном для просмотра кода. Как только я переместил его на экран большего размера, промежуток между ними заработал совершенно нормально. Я думал, что схожу с ума, но разобрался в проблеме

По какой-то причине мой justify-content: space -ween не разделяет мои предметы. Теги h1, button и select в классе .controls располагаются рядом друг с другом, когда они должны быть разнесены с пробелом между

. Это мой HTML & CSS и класс .controls. Пространство justify-content не разделяет элементы. Примечание. У меня также есть 2 других раздела в моих HTML, обозначенных как snare и hihat, но HTML выше показывает только раздел удара

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: sans-serif;
}

i,
svg {
  pointer-events: none;
}

.kick-pad,
.snare-pad,
.hihat-pad {
  width: 5rem;
  height: 5rem;
  margin: 1rem 0.5rem;
  cursor: pointer;
}

.hihat-track,
.snare-track,
.kick-track {
  display: flex;
  align-items: center;
  width: 70%;
  justify-content: space-between;
  margin-top: 4rem;
}

.sequencer {
  display: flex;
  min-height: 100vh;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.kick,
.snare,
.hihat {
  display: flex;
}

.controls {
  display: flex;
  justify-content: space-between;
  align-self: center;
  flex: 1;
  margin: 0rem 2rem;
}

.controls button {
  padding: 1rem;
  border: none;
  background: rgb(88, 88, 88);
  color: white;
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.5s ease;
}

.pad {
  transition: all 0.5s ease;
}

.play {
  padding: 1rem 2rem;
  font-size: 1.5rem;
  background: rgb(88, 88, 88);
  border: none;
  color: white;
  cursor: pointer;
  margin-top: 3rem;
}

select {
  padding: 1rem;
  font-size: 1rem;
}
<div class="sequencer">
      <div class="kick-track">
        <div class="controls">
          <h1>Kick</h1>
          <button data-track="0" class="mute kick-volume">
            <i class="fas fa-volume-mute"></i>
          </button>
          <select name="kick-select" id="kick-select">
            <option value="./sounds/kick-classic.wav">Classic Kick</option>
            <option value="./sounds/kick-808.wav">808 Kick</option>
            <option value="./sounds/kick-heavy.wav">Kick Heavy</option>
          </select>
        </div>
        <div class="kick">
          <div class="pad kick-pad b0"></div>
          <div class="pad kick-pad b1"></div>
          <div class="pad kick-pad b2"></div>
          <div class="pad kick-pad b3"></div>
          <div class="pad kick-pad b4"></div>
          <div class="pad kick-pad b5"></div>
          <div class="pad kick-pad b6"></div>
          <div class="pad kick-pad b7"></div>
        </div>
      </div>

 

Вот изображение того, как оно выглядит в данный момент, и я не знаю, почему они застряли рядом, хотя я использую justify-content: пространство между ними. enter image description here

1 Ответ

0 голосов
/ 07 апреля 2020

Я бы рекомендовал добавить некоторую ширину в класс, например

.controls { width: 20vw; } или .controls { width: 100%; }

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...