从Bootstrap 3的列中删除填充


342

问题:

删除Bootstrap 3中col-md- *左右的填充/边距。

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>

所需的输出:

当前,此代码在两列的右侧和左侧添加了填充/边距。我想知道要删除侧面的多余空间是什么吗?

注意:

如果我删除“ col-md-4”,则两列都将扩展为100%,但我希望它们彼此相邻。


1
对于Bootstrap 4,请使用pl-0 pr-0<div class="col-7 pl-0 pr-0">
穆罕默德·沙扎德

Answers:


454

通常,您通常.row要包装两列,而不是包装两列.col-md-12。毕竟,.row它没有a col-md-12会带来的多余边距和填充,并且也没有折扣列将以负的左右边距引入的空间。

<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>

如果您确实要删除填充/边距,请添加一个类以过滤每个子列的填充/边距。

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

甚至需要在容器类中添加.without-padding吗?我想说,使用您提供的CSS代码将.nopadding添加到.col-md-8 div中就足够了。
查尔斯·英格尔斯

58
我通常在自定义CSS中创建3个额外的类,即将.padding-0左右填充(仅)设置为0;.padding-sm将填充设置为2px .padding-md,并将填充设置为5px。通常的填充为15px(除非自定义),所以这些额外的类就足够了。
MichaelJTaylor 2014年

顺便说一句。行移动了它的新线
ozanmuyes

6
通常的填充是在变量中自定义的。less@ grid-gutter-width:30px;
弗拉迪斯拉夫·列

6
是否有任何预定义的引导程序来删除填充或创建类是唯一的解决方案
Gaurav Aggarwal,2015年

186

Bootstrap 4添加了.no-guttersclass

Bootstrap 3:我总是将此样式添加到我的Bootstrap LESS / SASS中:

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

然后,您可以在HTML中编写:

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

如果只想定位子列,则可以使用子选择器(感谢John Wu)。

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

您可能还希望仅删除某些设备尺寸的填充物(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;
    }
  }
}

如果希望媒体查询向上支持小型设备,则可以删除其最大宽度部分。


10
除了嵌套(这也在SASS中)之外,这是普通的CSS,因此它应该工作相同。
martinedwards

4
我建议使用直接子选择器来提高性能。使用& >[class*="col-"]代替。
约翰·吴

3
@JohnWu还可以防止嵌套行继承样式,这给我带来了一些麻烦。谢谢!
Troy Carlson

2
您确实应该使用它,[class^="col-"], [class*=" col-"] {...}这样您就不会偶然将目标命名foocol-为类。这将定位在开始时具有该类名称的元素,或者将其作为辅助类,而不定位在另一个类名称中找到该字符串的位置。
Brett

1
圣烟!我只是花了几个小时来解决我认为是iOS视口错误的问题,因为我的iPhone 6有时会(但不一致)自动放大我的网页。删除col填充后,我认为自动缩放功能正常!谢谢!
瑞安

45

navbar表示,仅减少列上的填充不会成功,因为您将扩展页面的宽度,使其与页面的其余部分不均匀。您需要同样减少行上的负边距。以@martinedwards的LESS为例:

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

仅当您的行不在容器或其他列中时,这才是问题。负边距仅抵消了这些元素的填充量
Fred Stark

我需要!important两个边际才能完成这项工作
Philip Bijker

22

专门用于SASS mixin:

@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");

然后在HTML中,您可以使用

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

当然,您只能@include您需要的那些声明。


我试图在这种情况下使用此mixin(感谢),并且对其填充无效。 .banners-home { @include make-row(); .banner-comprar,.banner-pq{ @include no-padding("all"); @include make-xs-column(6); @include make-sm-column(6); @include make-md-column(6); @include make-lg-column(6); } .banner-simulador{ @include no-padding("all"); @include make-xs-column(12); @include make-sm-column(12); @include make-md-column(12); @include make-lg-column(12); } }
jpcmf80

我找出问题所在。我需要为此解决方案创建另一个mixin。顺便说一句,感谢您的SASS mixin :)
jpcmf80

我只是@mixin nopadding{ padding:0!important; }在我的_mixin.scss@include nopadding;代码, 然后将其添加到上面的代码中。:)
jpcmf80




10

仅当从LESS源编译引导程序时,另一种可行的解决方案是重新定义用于设置列填充的变量。

您会在variables.less文件中找到该变量:它称为@grid-gutter-width

在源代码中是这样描述的:

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

将此设置为0,进行编译bootstrap.less,并包含结果bootstrap.css。大功告成 如果您已经使用过像我一样的引导源,则可以用它作为定义其他规则的替代方法。


6

自版本3.4.0起,Bootstrap 3 具有删除填充的官方方法:class row-no-gutters

文档中的示例:

<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>



3

上述解决方案都不适合我。遵循此答案,我能够创建对我有用的东西。在这里,我还使用媒体查询将其限制为仅小屏幕。

@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

使用引导程序3.7.7或更低版​​本删除黑白列的间距。

.no-gutter是一个自定义类,可以将其添加到行DIV中

.no-gutter > [class*='col-'] {
        padding-right:0;
        padding-left:0;
    }

这有效,不需要LESS或SASS。我确实注意到,我必须将容器类添加到我的行中,并应用以下额外样式:margin:0 auto;
Volomike

开发人员将需要意识到,一旦完成,他们需要在列内创建DIV并对其应用边距,以创建自己的装订线大小。
Volomike

2
<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>

您可以在col-md-4内的div中添加一类行,该行的-15px边距将平衡列中的装订线。很好的解释这里大约在引导3排水沟和行。


2

我想使用起来更容易

margin:-30px;

覆盖引导程序设置的原始值。

我试过了

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

它为我工作。


1

将您的列包装为.row并将其添加到该div类中,称为“ 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>

然后将以下内容粘贴到您的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

使用CSS参考删除/自定义Bootstrap装订线: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>


0

您可以创建一个用于删除边距的新类,并将其应用于要删除多余边距的元素:

.margL0 { margin-left:0 !important }

!重要:它将帮助您删除默认边距或覆盖当前边距值

并应用于您要从其中删除边距的div


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>

请您提供答案的解释。
PKirby

在<head>标记之前或之后提供这些代码,这样它将覆盖该页面中的那些类属性
Sreelakshmi 2015年

0

您可以使用引导程序创建Less Mixins,以管理列的边距和填充,例如,

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

用法:

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

同样,您可以使用将边距/填充零设置为零,

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

似乎基本信息在随后的链接页面上。这不是SO的方式。在您的答案中添加必要的信息!
jogo 2015年

或者人们可以使用已接受的答案,其中有159个否决票而没有任何否决票,这已经存在两年了。或者是其他十多个投票答案之一。您将不得不更加努力地在该页面上赢得该比赛的席位。
Tom Zych

0

Vitaliy Silin的答案为基础。不仅涵盖根本不需要填充的情况,还涵盖了我们具有标准尺寸填充的情况。

在sassmeister.com上查看此代码到CSS的实时转换

@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);
  }
}

然后输出:

.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

有时,您可能会丢失想要的列填充。他们最终彼此紧贴。为防止这种情况,您可以按如下所示更新类:

<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>

和相应的类:

.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

如果您下载带有SASS文件的引导程序,则可以在有设置列边距的地方编辑配置文件,然后将其保存,这样SASS可以计算出列的新宽度


0

您可以自定义Bootstrap Grid系统并定义自定义响应网格。

将以下装订线宽度的默认值从@grid-gutter-width = 30px更改为@grid-gutter-width = 0px

(装订线宽度是两列之间的填充。它被分成左右两半。)


0

我仍然更喜欢控制每个屏幕尺寸中的每个填充,因此此CSS可能对你们有用:)

.nopadding-lg {
    padding-left: 0!important;
    padding-right: 0!important;
}
.nopadding-left-lg {padding-left: 0!important;}
.nopadding-right-lg {padding-right: 0!important;}

@media (max-width: 576px) {
    .nopadding-xs {
        padding-left: 0!important;
        padding-right: 0!important;
    }
    .nopadding-left-xs {padding-left: 0!important;}
    .nopadding-right-xs {padding-right: 0!important;}
}

@media (max-width: 768px) {
    .nopadding-sm {
        padding-left: 0!important;
        padding-right: 0!important;
    }
    .nopadding-left-sm {padding-left: 0!important;}
    .nopadding-right-sm {padding-right: 0!important;}
}
@media (max-width: 992px) {
    .nopadding-md {
        padding-left: 0!important;
        padding-right: 0!important;
    }
    .nopadding-left-md {padding-left: 0!important;}
    .nopadding-right-md {padding-right: 0!important;}
}

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.