bootstrap 4 table colonne dimensionnement
bootstrap 3 je pourrais appliquer col-sm-xxth les balises thead et redimensionnez les colonnes de la table à volonté. Cependant cela ne fonctionne pas dans bootstrap 4. Comment puis-je réaliser quelque chose comme ça dans bootstrap 4?
<thead>
<th class="col-sm-3">3 columns wide</th>
<th class="col-sm-5">5 columns wide</th>
<th class="col-sm-4">4 columns wide</th>
</thead>
en regardant le codeply pourvu qu'il ne se taille pas correctement, surtout si vous ajoutez quelques données à la table. Voir comment cela fonctionne:
<div class="container" style="border: 1px solid black;">
    <table class="table table-bordered">
    <thead>
        <tr class="row">
            <th class="col-sm-3">3 columns wide</th>
            <th class="col-sm-5">5 columns wide</th>
            <th class="col-sm-4">4 columns wide</th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <td>123</td>
            <td>456</td>
            <td>789</td>
        </tr>
    </tbody>
</table>
</div>
6 réponses
mise à jour 2018
 assurez-vous que votre table inclut le table classe. C'est parce que Bootstrap 4 tables sont "opt-in"table la classe doit être intentionnellement ajoutée au tableau.
http://codeply.com/go/zJLXypKZxL
Bootstrap 3.x avait aussi quelques CSS pour réinitialiser les cellules de la table afin qu'elles ne flottent pas..
table td[class*=col-], table th[class*=col-] {
    position: static;
    display: table-cell;
    float: none;
}
je ne sais pas pourquoi ce n'est pas Bootstrap 4 alpha, mais il peut être ajouté dans la version finale. Ajouter ce CSS aidera toutes les colonnes à utiliser les largeurs définies dans le thead..
mise à JOUR (comme Bootstrap 4.0.0)
maintenant que Bootstrap 4 est flexbox, les cellules de la table ne prendront pas la bonne largeur en ajoutant col-*. Une solution de contournement consiste à utiliser le d-inline-block classe sur les cellules de la table pour empêcher l'affichage par défaut:flex colonne.
une autre option dans BS4 est d'utiliser les classes utils de dimensionnement pour la largeur...
<thead>
     <tr>
           <th class="w-25">25</th>
           <th class="w-50">50</th>
           <th class="w-25">25</th>
     </tr>
</thead>
Enfin, vous pouvez utiliser d-flex sur les lignes de la table (tr), et le col-* classes de grille sur les colonnes (th,td)...
<table class="table table-bordered">
        <thead>
            <tr class="d-flex">
                <th class="col-3">25%</th>
                <th class="col-3">25%</th>
                <th class="col-6">50%</th>
            </tr>
        </thead>
        <tbody>
            <tr class="d-flex">
                <td class="col-sm-3">..</td>
                <td class="col-sm-3">..</td>
                <td class="col-sm-6">..</td>
            </tr>
        </tbody>
    </table>
 une autre option est d'appliquer le style flex à la rangée de la table, et ajouter le col-classes de l'en-tête de table / tableau des éléments de données:
<table>
  <thead>
    <tr class="d-flex">
      <th class="col-3">3 columns wide header</th>
      <th class="col-sm-5">5 columns wide header</th>
      <th class="col-sm-4">4 columns wide header</th>
    </tr>
  </thead>
  <tbody>
    <tr class="d-flex">
      <td class="col-3">3 columns wide content</th>
      <td class="col-sm-5">5 columns wide content</th>
      <td class="col-sm-4">4 columns wide content</th>
    </tr>
  </tbody>
</table>
la classe de taille des colonnes du tableau a été changée de
<th class="col-sm-3">3 columns wide</th>
<th class="col-3">3 columns wide</th>
A partir D'Alpha 6, Vous pouvez créer le fichier sass suivant:
@each $breakpoint in map-keys($grid-breakpoints) {
  $infix: breakpoint-infix($breakpoint, $grid-breakpoints);
  col, td, th {
    @for $i from 1 through $grid-columns {
        &.col#{$infix}-#{$i} {
          flex: none;
          position: initial;
        }
    }
    @include media-breakpoint-up($breakpoint, $grid-breakpoints) {
      @for $i from 1 through $grid-columns {
        &.col#{$infix}-#{$i} {
          width: 100% / $grid-columns * $i;
        }
      }
    }
  }
}
je peux résoudre ce problème en utilisant le code suivant en utilisant Bootstrap 4:
<table class="table">
  <tbody>
    <tr class="d-flex">
      <th class="col-3" scope="row">Indicador:</th>
      <td class="col-9">this is my indicator</td>
    </tr>
    <tr class="d-flex">
      <th class="col-3" scope="row">Definición:</th>
      <td class="col-9">This is my definition</td>
    </tr>
  </tbody>
</table>
J'ai hacké ceci pour la version Bootstrap 4.1.1 selon mes besoins avant de voir le post de @florian_korner. Ressemble beaucoup.
si vous utilisez sass vous pouvez coller cet extrait à la fin de votre bootstrap includes. Il semble corriger la question pour chrome, IE, et edge. Ne semble pas casser quoi que ce soit dans firefox.
@mixin make-td-col($size, $columns: $grid-columns) {
    width: percentage($size / $columns);
}
@each $breakpoint in map-keys($grid-breakpoints) {
    $infix: breakpoint-infix($breakpoint, $grid-breakpoints);
    @for $i from 1 through $grid-columns {
        td.col#{$infix}-#{$i}, th.col#{$infix}-#{$i} {
            @include make-td-col($i, $grid-columns);
        }
    }
}
ou si vous voulez juste le css compilé utilitaire:
td.col-1, th.col-1 {
  width: 8.33333%; }
td.col-2, th.col-2 {
  width: 16.66667%; }
td.col-3, th.col-3 {
  width: 25%; }
td.col-4, th.col-4 {
  width: 33.33333%; }
td.col-5, th.col-5 {
  width: 41.66667%; }
td.col-6, th.col-6 {
  width: 50%; }
td.col-7, th.col-7 {
  width: 58.33333%; }
td.col-8, th.col-8 {
  width: 66.66667%; }
td.col-9, th.col-9 {
  width: 75%; }
td.col-10, th.col-10 {
  width: 83.33333%; }
td.col-11, th.col-11 {
  width: 91.66667%; }
td.col-12, th.col-12 {
  width: 100%; }
td.col-sm-1, th.col-sm-1 {
  width: 8.33333%; }
td.col-sm-2, th.col-sm-2 {
  width: 16.66667%; }
td.col-sm-3, th.col-sm-3 {
  width: 25%; }
td.col-sm-4, th.col-sm-4 {
  width: 33.33333%; }
td.col-sm-5, th.col-sm-5 {
  width: 41.66667%; }
td.col-sm-6, th.col-sm-6 {
  width: 50%; }
td.col-sm-7, th.col-sm-7 {
  width: 58.33333%; }
td.col-sm-8, th.col-sm-8 {
  width: 66.66667%; }
td.col-sm-9, th.col-sm-9 {
  width: 75%; }
td.col-sm-10, th.col-sm-10 {
  width: 83.33333%; }
td.col-sm-11, th.col-sm-11 {
  width: 91.66667%; }
td.col-sm-12, th.col-sm-12 {
  width: 100%; }
td.col-md-1, th.col-md-1 {
  width: 8.33333%; }
td.col-md-2, th.col-md-2 {
  width: 16.66667%; }
td.col-md-3, th.col-md-3 {
  width: 25%; }
td.col-md-4, th.col-md-4 {
  width: 33.33333%; }
td.col-md-5, th.col-md-5 {
  width: 41.66667%; }
td.col-md-6, th.col-md-6 {
  width: 50%; }
td.col-md-7, th.col-md-7 {
  width: 58.33333%; }
td.col-md-8, th.col-md-8 {
  width: 66.66667%; }
td.col-md-9, th.col-md-9 {
  width: 75%; }
td.col-md-10, th.col-md-10 {
  width: 83.33333%; }
td.col-md-11, th.col-md-11 {
  width: 91.66667%; }
td.col-md-12, th.col-md-12 {
  width: 100%; }
td.col-lg-1, th.col-lg-1 {
  width: 8.33333%; }
td.col-lg-2, th.col-lg-2 {
  width: 16.66667%; }
td.col-lg-3, th.col-lg-3 {
  width: 25%; }
td.col-lg-4, th.col-lg-4 {
  width: 33.33333%; }
td.col-lg-5, th.col-lg-5 {
  width: 41.66667%; }
td.col-lg-6, th.col-lg-6 {
  width: 50%; }
td.col-lg-7, th.col-lg-7 {
  width: 58.33333%; }
td.col-lg-8, th.col-lg-8 {
  width: 66.66667%; }
td.col-lg-9, th.col-lg-9 {
  width: 75%; }
td.col-lg-10, th.col-lg-10 {
  width: 83.33333%; }
td.col-lg-11, th.col-lg-11 {
  width: 91.66667%; }
td.col-lg-12, th.col-lg-12 {
  width: 100%; }
td.col-xl-1, th.col-xl-1 {
  width: 8.33333%; }
td.col-xl-2, th.col-xl-2 {
  width: 16.66667%; }
td.col-xl-3, th.col-xl-3 {
  width: 25%; }
td.col-xl-4, th.col-xl-4 {
  width: 33.33333%; }
td.col-xl-5, th.col-xl-5 {
  width: 41.66667%; }
td.col-xl-6, th.col-xl-6 {
  width: 50%; }
td.col-xl-7, th.col-xl-7 {
  width: 58.33333%; }
td.col-xl-8, th.col-xl-8 {
  width: 66.66667%; }
td.col-xl-9, th.col-xl-9 {
  width: 75%; }
td.col-xl-10, th.col-xl-10 {
  width: 83.33333%; }
td.col-xl-11, th.col-xl-11 {
  width: 91.66667%; }
td.col-xl-12, th.col-xl-12 {
  width: 100%; }