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
гибкий контейнер, поскольку второй элемент увеличивается, а его текст выравнивается вправо