web-dev-qa-db-fra.com

Mettre en place une boîte flexible semblable à une table?

Je travaille avec un framework développé en interne qui dépend d'une certaine structure de notre HTML. Et l'une des choses délicates est que chaque ligne a besoin de son propre conteneur avec ses propres classes et attributs de données.

Alors voici le problème. Sans changer radicalement le DOM, comment puis-je rendre le flex box ci-dessous rendu essentiellement comme un tableau HTML? Ou est-ce qu'une table est le seul moyen? La solution devra fonctionner dans IE11 et Chrome.

J'essaye de faire ressembler ça à ça ...

Column A      |      Column B      |      Column C
1             |      2             |      3

section {
  display: flex;
  flex-wrap: wrap;
}

section .col {
  flex: 1 1 auto;
}

section .line-break {
  flex-basis: 100%;
  width: 0px; 
  height: 0px; 
  overflow: hidden;
}
<html>
  <head>
  </head>
  <body>
    <section>
      <header>
        <div class="col">Column A</div>
        <div class="col">Column B</div>
        <div class="col">Column C</div>
      </header>
      <div class="line-break"></div>
      <div class="row">
        <div class="col">1</div>
        <div class="col">2</div>
        <div class="col">3</div>
      </div>
    </section>
  </body>
</html>

5
Steve Wortham

Si le contenu que vous allez présenter est de type tabular data, alors CSS Table est le moyen approprié.

Comme cela peut être fait en utilisant CSS, vous pouvez facilement basculer entre tout type d'affichage tel que flex, block, etc., ou même float, en utilisant une requête multimédia, etc.

J'ai également supprimé l'élément <div class="line-break"></div>, puisque vous n'en avez pas besoin, mais s'il est rendu par un composant ou similaire, le laisser tel quel ne posera pas de problème.


Si vous avez toujours besoin ou devez utiliser Flexbox, vous trouverez dans cette réponse la différence entre CSS Table et Flexbox sur deux caractéristiques importantes:


Updated, un exemple montrant des informations utiles sur la Flexbox, avec des colonnes de largeur et de largeur variables.

Extrait de pile - Flexbox ( Fiddle démo pour IE11 )

.tbl {
  display: flex;
  flex-direction: column;
}
.row {
  display: flex;
  min-height: 50px;
}
.cell {
  flex: 4;
  border: 1px solid red;
}
.cell:nth-child(1) {
  flex: 1;
}
.cell:nth-child(2) {
  flex: 2;
}
.cell.span4-5 {
  flex: 8 24px;                    /*  col 4,5 flex-grow/border/padding  */
}
.cell.span3-4 {
  flex: 8 24px;                    /*  col 3,4 flex-grow/border/padding  */
}
.cell.span3-5 {
  flex: 12 36px;                   /*  col 3,4,5 flex-grow/border/padding  */
}
.row:first-child .cell {
  display: flex;
  justify-content: center;         /*  center horiz. */
  align-items: center;             /*  center vert. */
}
.row .cell {
  padding: 5px;
  box-sizing: border-box;
}
<div class="tbl">
  <div class="row">
    <div class="cell">ID </div>
    <div class="cell">Nr </div>
    <div class="cell">Header 1 </div>
    <div class="cell span4-5"> Header 2 </div>
  </div>
  <div class="row">
    <div class="cell">1</div>
    <div class="cell">2</div>
    <div class="cell">Content</div>
    <div class="cell">Content</div>
    <div class="cell">Content</div>
  </div>
  <div class="row">
    <div class="cell">2</div>
    <div class="cell">3</div>
    <div class="cell span3-5">Content</div>
  </div>
  <div class="row">
    <div class="cell">1</div>
    <div class="cell">2</div>
    <div class="cell span3-4">Content</div>
    <div class="cell">Content</div>
  </div>
</div>


Extrait de pile - Table CSS

section {
  display: table;
  width: 100%;
}

section > * {
  display: table-row;
}

section .col {
  display: table-cell;
}
<html>
  <head>
  </head>
  <body>
    <section>
      <header>
        <div class="col">Column A</div>
        <div class="col">Column B</div>
        <div class="col">Column C</div>
      </header>
      <div class="row">
        <div class="col">1</div>
        <div class="col">2</div>
        <div class="col">3</div>
      </div>
    </section>
  </body>
</html>

7
LGSon

header, .row {
  display: flex;  /* aligns all child elements (flex items) in a row */
}

.col {
  flex: 1;        /* distributes space on the line equally among items */
}
<section>
  <header>
    <div class="col">Column A</div>
    <div class="col">Column B</div>
    <div class="col">Column C</div>
  </header>
  <div class="row">
    <div class="col">1</div>
    <div class="col">2</div>
    <div class="col">3</div>
  </div>
</section>

0
Michael_B