Comment puis-je créer une grille 3x3 via CSS?

9 divs l'un après l'autre, je veux créer une grille de 3X3 via CSS.

Comment dois-je faire?

CSS:

.cell {
  height: 50px;
  width: 50px;
  background-color: #999;
  display: inline-block;
}

.cell:nth-child(3n) {
  background-color: #F00;
  /* what property should I use to get a line break after this element? */
}

/* this doesn't work; at least not in safari */
.cell:nth-child(3n)::after {
  display: block;
}

HTML:

<div class="grid">
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
</div>


Remarque: je ne veux pas float/clear solution. L'accent est sur le CSS et pas en HTML restructurer.

Si j'ajoute content: '\A'; white-space: pre; à ::after de sortie vient d'être laid.

CSS:

.cell {
  height: 50px;
  width: 50px;
  background-color: #999;
  display: inline-block;
}

.cell:nth-child(3n) {
  background-color: #F00;
  /* what property should I use to get a line break after this element? */
}

.cell:nth-child(3n)::after {
  display: inline;
  content: '\A';
  white-space: pre;
}

HTML:

<div class="grid">
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
  <div class="cell"></div>
</div>

Comment puis-je obtenir tous les div dans un 3X3 ligne-colonne mise en page?

InformationsquelleAutor | 2016-05-28