web-dev-qa-db-fra.com

Supprimer le remplissage des colonnes dans Bootstrap 3

Problème:

Supprimez le rembourrage/la marge à droite et à gauche de col-md- * dans Bootstrap 3.

Code HTML:

<div class="col-md-12">
    <h2>OntoExplorer<span style="color:#b92429">.</span></h2>

    <div class="col-md-4">
        <div class="widget">
            <div class="widget-header">
                <h3>Dimensions</h3>
            </div>

            <div class="widget-content" id="">
                <div id='jqxWidget'>
                    <div style="clear:both;margin-bottom:20px;" id="listBoxA"></div>
                    <div style="clear:both;" id="listBoxB"></div>

                </div>
            </div>
        </div>
    </div>

    <div class="col-md-8">
        <div class="widget">
            <div class="widget-header">
                <h3>Results</h3>
            </div>

            <div class="widget-content">
                <div id="map_canvas" style="height: 362px;"></div>
            </div>
        </div>
    </div>

</div>

Sortie désirée:

Actuellement, ce code ajoute des marges/marges à droite et à gauche des deux colonnes. Je me demande ce qui me manque pour supprimer cet espace supplémentaire sur les côtés?

Remarquer:

Si je supprime "col-md-4", les deux colonnes sont étendues à 100% mais je veux qu'elles soient côte à côte.

300
kexxcream

Vous devez normalement utiliser .row pour envelopper deux colonnes, et non pas .col-md-12 - qui est une colonne contenant une autre colonne. Après tout, .row ne dispose pas des marges supplémentaires et du remplissage qu'un col-md-12 apporterait, ni de l'espace disponible qu'une colonne introduirait avec des marges gauche et droite négatives. 

<div class="container">
    <div class="row">
        <h2>OntoExplorer<span style="color:#b92429">.</span></h2>

        <div class="col-md-4 nopadding">
            <div class="widget">
                <div class="widget-header">
                    <h3>Dimensions</h3>
                </div>
                <div class="widget-content">
                </div>
            </div>
        </div>

        <div class="col-md-8 nopadding">
            <div class="widget">
                <div class="widget-header">
                    <h3>Results</h3>
                </div>
                <div class="widget-content">
                </div>
            </div>
        </div>
    </div>
</div>

si vous vraiment vouliez supprimer le remplissage/les marges, ajoutez une classe pour filtrer les marges/le remplissage de chaque colonne enfant. 

.nopadding {
   padding: 0 !important;
   margin: 0 !important;
}
413
MackieeE

J'ajoute toujours ce style à mon Bootstrap LESS/SASS:

.row-no-padding {
  [class*="col-"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

Ensuite, dans le HTML, vous pouvez écrire:

<div class="row row-no-padding">

Si vous souhaitez cibler uniquement les colonnes enfants, vous pouvez utiliser le sélecteur d'enfants (Merci, John Wu).

.row-no-padding > [class*="col-"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

Vous souhaiterez peut-être également supprimer le remplissage pour certaines tailles de périphérique (exemple SASS):

/* Small devices (tablets, 768px and up) */
@media (min-width: $screen-sm-min) and (max-width: $screen-sm-max) {
  .row-sm-no-padding {
    [class*="col-"] {
      padding-left: 0 !important;
      padding-right: 0 !important;
    }
  }
}

Vous pouvez supprimer la partie de largeur maximale de la requête multimédia si vous souhaitez que celle-ci prenne en charge les petits périphériques à la hausse.

165
martinedwards

Réduire uniquement le remplissage des colonnes ne fera pas l'affaire, car vous allez agrandir la page, ce qui la rend inégale avec le reste de votre page, par exemple, barre de navigation. Vous devez également réduire la marge négative sur la ligne. Prenons l'exemple de @martinedwards 'LESS:

.row-no-padding {
  margin-left: 0;
  margin-right: 0;
  [class*="col-"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}
41
phoeb

Spécifiquement pour le mixin SASS:

@mixin no-padding($side) {
    @if $side == 'all' {
        .no-padding {
            padding: 0 !important;
        }
    } @else {
        .no-padding-#{$side} {
            padding-#{$side}: 0 !important;
        }
    }
}

@include no-padding("left");
@include no-padding("right");
@include no-padding("top");
@include no-padding("bottom");
@include no-padding("all");

Ensuite, en HTML, vous pouvez utiliser 

.no-padding-left
.no-padding-right
.no-padding-bottom
.no-padding-top
.no-padding - to remove padding from all sides

Bien sûr, vous ne pouvez inclure que les déclarations dont vous avez besoin.

22
Vitaliy Silin

ajoutez simplement "no-padding" qui est une classe intégrée dans bootstrap 3

16
bhargav

Ci-après uniquement disponible sur Bootstrap4

<div class="p-0 m-0">
</div>

note: .p-0 et .m-0 déjà ajoutés bootstrap.css

9
Ali Göksel Bektaş

Une autre solution, réalisable uniquement si vous compilez bootstrap à partir de ses sources LESS, consiste à redéfinir la variable qui définit le remplissage des colonnes.

Vous trouverez la variable dans le fichier variables.less: il s’appelle @grid-Gutter-width.

C'est décrit comme ça dans les sources:

//** Padding between columns. Gets divided in half for the left and right.
@grid-Gutter-width:         30px;

Définissez-le sur 0, compilez bootstrap.less et incluez le bootstrap.css résultant. Vous avez terminé. Cela peut être une alternative à la définition d'une règle supplémentaire, si vous utilisez déjà des sources d'amorçage comme je le suis.

9
link

Bootstrap 4 a une classe native pour le faire: ajoute la classe .no-gutters au parent .row

7
[class*="col-"]
  padding: 0
  margin: 0
6
Sharpless512

Aucune des solutions ci-dessus ne fonctionnait parfaitement pour moi. Après cette réponse j’ai pu créer quelque chose qui fonctionne pour moi. Ici, j'utilise également une requête de média pour limiter cela aux seuls petits écrans.

@media (max-width: @screen-sm) {
    [class*="col-"] {
      padding-left: 0;
      padding-right: 0;
    }
    .row {
      margin-left: 0;
      margin-right: 0;
    }
    .container-fluid {
      margin: 0;
      padding: 0;
    }
}
3
rlv-dan

Je suppose qu'il est plus facile d'utiliser 

margin:-30px;

pour remplacer la valeur d'origine définie par bootstrap.

J'ai essayé 

margin: 0px -30px 0px -30px;

et cela a fonctionné pour moi.

2
Basheer
<div class="col-md-12">
<h2>OntoExplorer<span style="color:#b92429">.</span></h2>

<div class="col-md-4">
    <div class="widget row">
        <div class="widget-header">
            <h3>Dimensions</h3>
        </div>

        <div class="widget-content" id="">
            <div id='jqxWidget'>
                <div style="clear:both;margin-bottom:20px;" id="listBoxA"></div>
                <div style="clear:both;" id="listBoxB"></div>

            </div>
        </div>
    </div>
</div>

<div class="col-md-8">
    <div class="widget row">
        <div class="widget-header">
            <h3>Results</h3>
        </div>

        <div class="widget-content">
            <div id="map_canvas" style="height: 362px;"></div>
        </div>
    </div>
</div>

Vous pouvez ajouter une classe de ligne à la division à l'intérieur de col-md-4 et la marge de -15px de la ligne équilibrera la gouttière des colonnes. Bonne explication ici à propos des gouttières et des rangées dans Bootstrap 3.

2
1Bladesforhire

Bootstrap a la classe .no-gutters que vous pouvez ajouter à l’élément row. 

<div class="container-fluid">
    <div class="row no-gutters">
        <div class="col-md-12">
            [YOUR CONTENT HERE]
        </div>
    </div>
</div>

Référence: http://getbootstrap.com/docs/4.0/layout/grid/#grid-options

1
Kelly Baker

Supprimer/personnaliser Bootstrap Gutter avec css Reference: http://arnique.net/web-design/58/a-quick-guide-to-changing-bootstraps-Gutter-width/

/* remove */
.Gutter-0.row {
  margin-right: -0px;
  margin-left: -0px;
}
.Gutter-0 > [class^="col-"], .Gutter-0 > [class^=" col-"] {
  padding-right: 0px;
  padding-left: 0px;
}

/* customize */
.Gutter-6.row {
  margin-right: -3px;
  margin-left: -3px;
}
.Gutter-6 > [class^="col-"], .Gutter-6 > [class^=" col-"] {
  padding-right: 3px;
  padding-left: 3px;
}
    
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"/>
<div class="row Gutter-6">
  <div class="col-sm-3 col-md-3">
    <div class="thumbnail">
      <img width="100%" src="" alt="">
      <div class="caption">
        <h3>Thumbnail label</h3>
        <p>more</p>
        <p><a href="#" class="btn btn-primary" role="button">Button</a> <a href="#" class="btn btn-default" role="button">Button</a></p>
      </div>
    </div>
  </div>
  <div class="col-sm-3 col-md-3">
    <div class="thumbnail">
      <img width="100%" src="" alt="">
      <div class="caption">
        <h3>Thumbnail label</h3>
        <p>more</p>
        <p><a href="#" class="btn btn-primary" role="button">Button</a> <a href="#" class="btn btn-default" role="button">Button</a></p>
      </div>
    </div>
  </div>
  <div class="col-sm-3 col-md-3">
    <div class="thumbnail">
      <img width="100%" src="" alt="">
      <div class="caption">
        <h3>Thumbnail label</h3>
        <p>more</p>
        <p><a href="#" class="btn btn-primary" role="button">Button</a> <a href="#" class="btn btn-default" role="button">Button</a></p>
      </div>
    </div>
  </div>
  <div class="col-sm-3 col-md-3">
    <div class="thumbnail">
      <img width="100%" src="" alt="">
      <div class="caption">
        <h3>Thumbnail label</h3>
        <p>more</p>
        <p><a href="#" class="btn btn-primary" role="button">Button</a> <a href="#" class="btn btn-default" role="button">Button</a></p>
      </div>
    </div>
  </div>
</div>

1
haryx8

Enveloppez vos colonnes dans un .row et ajoutez à cette div une classe appelée "no-Gutter"

<div class="container">
  <div class="row no-Gutter">
    <h2>OntoExplorer<span style="color:#b92429">.</span></h2>

    <div class="col-md-4">
        <div class="widget">
            <div class="widget-header">
                <h3>Dimensions</h3>
            </div>
            <div class="widget-content">
            </div>
        </div>
    </div>

    <div class="col-md-8">
        <div class="widget">
            <div class="widget-header">
                <h3>Results</h3>
            </div>
            <div class="widget-content">
            </div>
        </div>
    </div>
</div>

Puis collez le contenu ci-dessous dans votre fichier CSS

.row.no-Gutter {
  margin-left: 0;
  margin-right: 0;
}

.row.no-Gutter [class*='col-']:not(:first-child),
.row.no-Gutter [class*='col-']:not(:last-child) {
  padding-right: 0;
  padding-left: 0;
}
1
Chi

Supprimez l’espacement des colonnes n/b à l’aide de bootstrap 3.7.7 ou inférieur. 

.no-Gutter est une classe personnalisée que vous pouvez ajouter à vos lignes DIV.

.no-Gutter > [class*='col-'] {
        padding-right:0;
        padding-left:0;
    }
1
Super Model

Si vous téléchargez bootstrap avec les fichiers SASS, vous pourrez éditer le fichier de configuration contenant un paramètre pour la marge des colonnes, puis l'enregistrer. Ainsi, le SASS calculera la nouvelle largeur des colonnes. 

0
TheCrazyProfessor

Bootstrap 3, depuis la version 3.4.0 , dispose d’une méthode officielle pour supprimer le remplissage: la classe row-no-gutters.

Exemple tiré de documentation

<div class="row row-no-gutters">
  <div class="col-xs-12 col-md-8">.col-xs-12 .col-md-8</div>
  <div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
</div>
<div class="row row-no-gutters">
  <div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
  <div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
  <div class="col-xs-6 col-md-4">.col-xs-6 .col-md-4</div>
</div>
<div class="row row-no-gutters">
  <div class="col-xs-6">.col-xs-6</div>
  <div class="col-xs-6">.col-xs-6</div>
</div>
0
Smi

Vous pouvez créer une nouvelle classe pour supprimer une marge et appliquer à l'élément pour lequel vous souhaitez supprimer une marge supplémentaire:

.margL0 { margin-left:0 !important }

! important : cela vous aidera à supprimer la marge par défaut ou à écraser la valeur de la marge actuelle 

et appliquer à cette div dans laquelle vous souhaitez supprimer la marge du côté gauche

0
Udit Bansal

Construire sur La réponse de Vitaliy Silin . Couvre non seulement les cas où nous ne voulons pas du tout de rembourrage, mais aussi les cas où nous avons des rembourrages de taille standard.

Voir la conversion en direct de ce code en CSS sur sassmeister.com

@mixin padding($side, $size) {
    $padding-size : 0;
    @if $size == 'xs' { $padding-size : 5px; }
    @else if $size == 's' { $padding-size : 10px; }
    @else if $size == 'm' { $padding-size : 15px; }
    @else if $size == 'l' { $padding-size : 20px; }

    @if $side == 'all' {
        .padding--#{$size} {
            padding: $padding-size !important;
        }
    } @else {
        .padding-#{$side}--#{$size} {
            padding-#{$side}: $padding-size !important;
        }
    }
}

$sides-list: all top right bottom left;
$sizes-list: none xs s m l;
@each $current-side in $sides-list {
  @each $current-size in $sizes-list {
    @include padding($current-side,$current-size);
  }
}

Cela génère ensuite:

.padding--none {
  padding: 0 !important;
}

.padding--xs {
  padding: 5px !important;
}

.padding--s {
  padding: 10px !important;
}

.padding--m {
  padding: 15px !important;
}

.padding--l {
  padding: 20px !important;
}

.padding-top--none {
  padding-top: 0 !important;
}

.padding-top--xs {
  padding-top: 5px !important;
}

.padding-top--s {
  padding-top: 10px !important;
}

.padding-top--m {
  padding-top: 15px !important;
}

.padding-top--l {
  padding-top: 20px !important;
}

.padding-right--none {
  padding-right: 0 !important;
}

.padding-right--xs {
  padding-right: 5px !important;
}

.padding-right--s {
  padding-right: 10px !important;
}

.padding-right--m {
  padding-right: 15px !important;
}

.padding-right--l {
  padding-right: 20px !important;
}

.padding-bottom--none {
  padding-bottom: 0 !important;
}

.padding-bottom--xs {
  padding-bottom: 5px !important;
}

.padding-bottom--s {
  padding-bottom: 10px !important;
}

.padding-bottom--m {
  padding-bottom: 15px !important;
}

.padding-bottom--l {
  padding-bottom: 20px !important;
}

.padding-left--none {
  padding-left: 0 !important;
}

.padding-left--xs {
  padding-left: 5px !important;
}

.padding-left--s {
  padding-left: 10px !important;
}

.padding-left--m {
  padding-left: 15px !important;
}

.padding-left--l {
  padding-left: 20px !important;
}
0
Adrien Be

Vous pouvez personnaliser votre système Bootstrap Grid et définir votre grille responsive personnalisée.

changez vos valeurs par défaut pour la largeur de gouttière suivante de @grid-Gutter-width = 30px à @grid-Gutter-width = 0px

(La largeur de la gouttière est un remplissage entre les colonnes. Elle est divisée en deux pour les côtés gauche et droit.)

0
Rafiqul Islam

Parfois, vous risquez de perdre le remplissage que vous souhaitez pour les colonnes. Ils finissent par se coller les uns aux autres. Pour éviter cela, vous pouvez mettre à jour la classe comme suit:

<div class="col-md-3 NoPaddingForChildren">
        <div class="col-md-6">
                    <label>Id</label>
                    <input ng-model="ID" class="form-control">
        </div>
        <div class="col-md-6">
                    <label>Value</label>
                    <input ng-model="Val" class="form-control">
        </div>
</div>

et classe correspondante:

.NoPaddingForChildren > div:not(:first-child):not(:last-child) {
    padding-left: 0;
    padding-right: 0;
}

.NoPaddingForChildren > div:first-child {
    padding-left: 0;
}

.NoPaddingForChildren > div:last-child {    
    padding-right: 0;
}
0
Mahesh
<style>
.col-md-12{
 padding-left:0px !important;
padding-right:0px !important;
}
.col-md-8{
padding-left:0px !important;
padding-right:0px !important;
}
.col-md-4{
padding-left:0px !important;
padding-right:0px !important;
}
</style>
0
Sreelakshmi

Vous pouvez créer moins de Mixins en utilisant bootstrap pour gérer les marges et les bourrages de vos colonnes comme, par exemple,

http://mohandere.work/less-mixins-for-margin-and-padding-with-bootstrap-3/

Utilisation: 

xs-padding-lr-15px//left right both
xs-padding-l-15px 
xs-padding-r-15px

De même pour définir la marge/remplissage zéro, vous pouvez utiliser,

xs-padding-lr-0px
xs-padding-l-0px
xs-padding-r-0px
0
Mohan Dere

vous pouvez utiliser une fourchette

https://github.com/srghma/bootstrap-rubygem-without-Gutter/commit/8e42c16dcc2f132af3489c2275dd7460b524d437

gem "bootstrap", github: "srghma/bootstrap-rubygem-without-Gutter"
0
srghma