<h1>flex-basis: auto;</h1>
<section class="container">
<div class="item basis-auto">Palavra 1</div>
<div class="item basis-auto">2</div>
<div class="item basis-auto-grow-2">3</div>
<div class="item basis-auto-width">4</div>
<div class="item basis-auto-grow-0">5</div>
</section>
<section class="container overlay">
<div class="item basis-auto">Palavra 1</div>
<div class="item basis-auto">2</div>
<div class="item basis-auto-grow-2">3</div>
<div class="item basis-auto-width">4</div>
<div class="item basis-auto-grow-0">5</div>
</section>
<h1>flex-basis: 0;</h1>
<section class="container">
<div class="item basis-0">Test de Cont</div>
<div class="item basis-0">2</div>
<div class="item basis-0-grow-2">Palavra</div>
<div class="item basis-0-width">4</div>
<div class="item basis-0-grow-0">5</div>
</section>
<section class="container overlay">
<div class="item basis-0">Test de Cont</div>
<div class="item basis-0">2</div>
<div class="item basis-0-grow-2">Palavra</div>
<div class="item basis-0-width">4</div>
<div class="item basis-0-grow-0">5</div>
</section>
<h1>flex-basis: número;</h1>
<section class="container basis-numero-container">
<div class="item basis-110">1</div>
<div class="item basis-110">12</div>
<div class="item basis-110">12345678910</div>
<div class="item basis-300">1234</div>
<div class="item basis-110-porcento">1</div>
<div class="item basis-110-porcento">12</div>
<div class="item basis-110-porcento">123</div>
<div class="item basis-110-porcento">1234</div>
</section>
<h1>flex-basis: número; // Diferente Conteúdo</h1>
<section class="container basis-numero-container">
<div class="item basis-110">Conteúdo Grande</div>
<div class="item basis-110">PalavraMaior</div>
<div class="item basis-110">Oi</div>
</section>
<h1>flex-basis: número; // grow 1</h1>
<section class="container basis-numero-container">
<div class="item basis-110-grow-1">1</div>
<div class="item basis-110-grow-1">12</div>
<div class="item basis-110-grow-1">1234</div>
<div class="item basis-110-grow-1">12345</div>
<div class="item basis-600-grow-1">5</div>
</section>
/* FLEX BASIS AUTO */
.basis-auto {
flex-grow: 1;
flex-basis: auto;
}
/* O espaço distribuído é 2 vezes maior que o flex-grow: 1; */
.basis-auto-grow-2 {
flex-grow: 2;
flex-basis: auto;
}
/* É o mesmo espaço distribuido que os demais itens com flex-grow: 1; Porém esse espaço inicia após os 60px iniciais */
.basis-auto-width {
flex-grow: 1;
flex-basis: auto;
width: 60px;
}
/* Com o flex-grow: 0; nada é distribuído */
.basis-auto-grow-0 {
flex-basis: auto;
}
.container.overlay {
margin-top: 10px;
}
.overlay .basis-auto::before, .overlay .basis-auto-grow-2::before, .overlay .basis-auto-width::before {
content: '';
display: block;
width: 16px;
height: 36px;
background: blue;
position: absolute;
opacity: .5;
}
.overlay .basis-auto-grow-2::before {
border-right: 16px solid blueviolet;
}
.overlay .basis-auto-width::before {
border-right: 30px solid;
}
/* FLEX BASIS AUTO FIM */
/* FLEX BASIS 0 */
/* Com o flex-basis 0, itens com flex-grow 1 tentam ficar com o mesmo tamanho total de width. É por isso que o mais comum é utilizar flex-basis 0 */
.basis-0 {
flex-grow: 1;
flex-basis: 0;
}
/* O tamanho total é de duas vezes dos itens com flex: 1; */
.basis-0-grow-2 {
flex-grow: 2;
flex-basis: 0;
}
/* A definição do width é ignorada. Porém ele ainda respeita a definição de min-width. */
.basis-0-width {
flex-grow: 1;
flex-basis: 0;
width: 120px;
min-width: 80px;
}
/* Flex basis 0 com flex-grow 0, não influenciar em nada no item. Assim o mesmo fica do tamanho do seu conteúdo. */
.basis-0-grow-0 {
flex-basis: 0;
}
.overlay .basis-0::before, .overlay .basis-0-grow-2::before, .overlay .basis-0-width::before {
content: '';
display: block;
width: 65px;
height: 36px;
background: blue;
position: absolute;
opacity: .5;
}
.overlay .basis-0-grow-2::before {
border-right: 65px solid blueviolet;
}
/* FLEX BASIS 0 FIM */
.basis-numero-container {
flex-wrap: wrap;
}
.basis-110 {
flex-basis: 110px;
}
.basis-300 {
flex-basis: 300px;
}
.basis-110-porcento {
flex-basis: calc(25% - 10px);
}
.basis-110-grow-1 {
flex-grow: 1;
flex-basis: 110px;
}
/* O Flex-basis não ultrapassa o tamanho do container. Pois por padrão o flex-shrink é 1, ou seja, ele permite que o item se ajuste para caber no container. */
.basis-600-grow-1 {
flex-grow: 1;
flex-basis: 600px;
}
/* ESTILOS GERAIS */
.item {
margin: 5px;
background: tomato;
text-align: center;
font-size: 1.5em;
position: relative;
}
/* Flex Container */
.container {
max-width: 400px;
margin: 0 auto;
display: flex;
border: 1px solid #ccc;
}
/* Flex Item */
img {
display: block;
max-width: 100%;
margin: 10px auto;
}
h1 {
text-align: center;
margin: 20px 0 0 0;
font-size: 1.25em;
font-weight: normal;
}
body {
font-family: monospace;
color: #333;
}
This Pen doesn't use any external CSS resources.
This Pen doesn't use any external JavaScript resources.