Как выровнять несколько элементов в одном Div с CSS - PullRequest
0 голосов
/ 18 апреля 2019

Я пытаюсь выровнять 4 элемента по горизонтали в одном div без особой удачи.

Я пробовал inline-block, float left с margin-rights для элементов, но ничего не выравнивает и не может использоватьнекоторая помощь.

Мои элементы:

return(
   <div className="counter">
       <p className="quantity">quantity: </p>
       <button className="counter-btn" id="decrease" onClick={this.decrementCount}>-</button>
       <p classname="count">{this.state.count}</p>
       <button className="counter-btn" id="increase" onClick={this.incrementCount}>+</button>
   </div>
  )

Мой CSS:

.counter {
  display: inline-block;
  border: 1px grey solid;
  width: 300px;
  flex-direction: column;
  margin-bottom: 2em;
}

.counter-btn {
  background-color: lightslategrey;
  border: none;
  border-radius: 25px;
  font-size: 1.5em;
  color: white;
}

.quantity {
  float:left;
  padding-right: 2em;
}
.decrease {
  /* float:left; */
}
.count {
  /* float: left; */
}

Вот как это должно выглядеть: correct-way

Вот как это выглядит в настоящее время: current-way

Могу ли я получить помощь по выравниванию?

Ответы [ 2 ]

1 голос
/ 18 апреля 2019

Flex может помочь вам с этим:

.counter {
    display: flex;
    align-items: center;
}
0 голосов
/ 18 апреля 2019

Вы были близки:

.counter {
  display: inline-block;
  border: 1px grey solid;
  width: 19em;
  flex-direction: column;
  margin-bottom: 2em;
  text-align: right;
  white-space: nowrap;
  font-family: sans-serif;
}

.counter-btn {
  background-color: lightslategrey;
  border: none;
  border-radius: 25px;
  font-size: 1.5em;
  color: white;
  display: inline-block;
}

.quantity {
  float:left;
  padding-right: 1em;
}
.count {
  display: inline-block;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...