<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;
}

External CSS

This Pen doesn't use any external CSS resources.

External JavaScript

This Pen doesn't use any external JavaScript resources.