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.
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;
}
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.
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;
}
}
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.
ajoutez simplement "no-padding" qui est une classe intégrée dans bootstrap 3
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
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.
Bootstrap 4 a une classe native pour le faire: ajoute la classe .no-gutters
au parent .row
[class*="col-"]
padding: 0
margin: 0
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;
}
}
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.
<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.
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
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>
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;
}
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;
}
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.
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>
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
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;
}
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.)
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;
}
<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>
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
vous pouvez utiliser une fourchette
gem "bootstrap", github: "srghma/bootstrap-rubygem-without-Gutter"