Могу ли я сделать элементы, которые установлены для justify-content: space -ween, выровнены вправо при переносе? - PullRequest
0 голосов
/ 01 мая 2018

У меня есть два элемента в контейнере, для которых установлены «display flex» и «justify-content space -ween». Это заставляет их отображаться на противоположной стороне друг от друга в контейнере. Если контейнер сжимается, я бы хотел, чтобы элемент слева располагался поверх элемента справа и выравнивался вправо. Поведение, которое я испытываю сейчас, заключается в том, что они переносятся, но элемент слева находится над правым элементом и выровнен по левому краю, а элемент справа выровнен по правому краю. Как я могу заставить их обоих выравниваться правильно?

Пожалуйста, имейте в виду, что я не могу использовать медиа-запрос, потому что у меня есть несколько ячеек, которые будут иметь различные данные. Таким образом, предметы должны быть обернуты в несколько размеров носителей, о которых я не буду знать заранее. Пожалуйста, смотрите мой CodePen для более подробной информации.

.u-relative {
  position: relative;
}

.u-centerY {
  display: flex;
  align-items: center;
}

.u-fillRemaining {
  flex: 1;
}

.u-spaceBetweenX {
  justify-content: space-between;
}

.u-wrap {
  flex-wrap: wrap;
}

.Rtable-cell {
  padding: 0 0.625rem;
  max-width: 12rem;
  min-width: 6.25rem;
  border: 1px solid black;
}

.table-sum {
  // visibility: hidden;
  text-transform: uppercase;
  color: Grey;
  font-size: 0.75rem;
}

.t-alignRight {
  text-align: right;
}

@media only screen and (max-width: 400px) {
  .u-spaceBetweenX {
    justify-content: flex-end;
  }
}
<div class="u-relative Rtable-cell">
  <div class="u-centerY u-fillRemaining u-spaceBetweenX u-wrap">
    <span class="table-sum">sum</span>
    <div class="u-fillRemaining t-alignRight">
      <p>$4,000,000.00</p>
    </div>
  </div>
</div>

Ответы [ 2 ]

0 голосов
/ 02 мая 2018

justify-content: flex-end выравнивает элементы внутри гибкого контейнера вправо.

настройка flex: 1 0 6rem означает, что область значений может увеличиваться, не может уменьшаться , а ее базовый размер равен половине родительского размера.

как только размер контейнера сжимается за пределы точки, в которой два элемента могут поместиться в одном ряду, второй элемент переносится во 2-й ряд, что заставляет первый элемент придерживаться вправо (из-за justify-content: flex-end.

Если вы хотите, чтобы эффект был, когда для текста недостаточно места, вы можете также уменьшить контейнер value, установив для второго параметра значение 1. это не будет сокращаться сверх его содержания:

flex: 1 1 6rem; /* now the minimum size can be less than 6rem if the text is shorter */

setInterval(() => {
  $('.width-change').toggleClass('short');
}, 2000);
.kb-container {
  padding: 0 0.625rem;
  max-width: 12rem;
  min-width: 6.25rem;
  border: 1px solid black;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  background: white;
}

.kb-value {
  flex: 1 0 6rem;
  text-align: right;
}


/* not necessary. just for this demo */

.width-change {
  width: 15rem;
  height: 7rem;
  transition: all 250ms;
  background: lightgrey;
}

.width-change.short {
  width: 9rem;
}

h3 {
  margin-bottom: 0;
}

.sub {
  margin: 3px 0;
}

body {
  overflow: hidden;
}

html {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

*,
*:before,
*:after {
  box-sizing: inherit;
}

.kb-example {
  width: 45vw;
  display: inline-block;
  height: 100vh;
}

.kb-example.kb-colorized .kb-text {
background-color: #ccffcc;
}

.kb-example.kb-colorized .kb-value {
background-color: #ccffff;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="kb-example">
  <h3>align items to the right using flex</h3>
  <div class="sub">(container will resize to demo the behavior)</div>
  <div class="width-change">
    <!-- YOU ONLY NEED THIS -->
    <div class="kb-container">
      <span class="kb-text">sum</span>
      <div class="kb-value">
        $4,000,000.00
      </div>
    </div>
    <!-- END -->
  </div>
</div>

<!-- with colorized elements -->
<div class="kb-example kb-colorized">
  <div class="sub">and now with x-ray:</div>
  <div class="width-change">
    <!-- YOU ONLY NEED THIS -->
    <div class="kb-container">
      <span class="kb-text">sum</span>
      <div class="kb-value">
        $4,000,000.00
      </div>
    </div>
    <!-- END -->
  </div>
</div>

также есть codepen (он содержит только код, необходимый для этого поведения, без дополнительного кода для демонстрации)

Несмотря на то, что это контейнер flex-end, он ведет себя как space-between гибкий контейнер, поскольку второй элемент увеличивается, а его текст выравнивается вправо

0 голосов
/ 01 мая 2018

добавьте это к своему коду и измените 400px на то, что вы хотите

@media only screen and (max-width: 400px) {
  .u-spaceBetweenX {
  justify-content: flex-end;
 }
} 

и если вы хотите, чтобы элементы выровнены по левому краю, измените justify-content: flex-start

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