374

问题:

在 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%,但我希望它们彼此相邻。

4

26 回答 26

493

您通常会使用.row包装两列,而不是.col-md-12- 那是包含另一列的列。毕竟,.row没有 acol-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;
}
于 2013-10-24T10:32:51.837 回答
216

Bootstrap 4添加了.no-gutters class

Bootstrap 3.4添加了.row-no-gutters 类

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

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

于 2014-05-19T15:46:53.607 回答
46

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

.row-no-padding {
  margin-left: 0;
  margin-right: 0;
  [class*="col-"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}
于 2014-08-10T21:41:04.093 回答
24

此后仅在 Bootstrap 4 可用

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

注意:.p-0 和 .m-0 已经添加了 bootstrap.css

于 2017-01-15T14:28:05.607 回答
22

专门针对 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");

然后在 HTML 中,你可以使用

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

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

于 2014-07-31T06:36:31.940 回答
17

只需添加“无填充”,这是引导程序 3 中的内置类

于 2016-08-19T11:57:56.253 回答
13

Bootstrap 4有一个本地类来执行此操作:将类添加.no-gutters到父级.row

于 2018-04-05T09:10:43.870 回答
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。你完成了。如果您已经像我一样使用引导程序源,它可以作为定义附加规则的替代方法。

于 2014-08-06T19:18:48.967 回答
10
于 2017-11-20T02:09:42.230 回答
7

从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>
于 2018-12-14T08:43:00.337 回答
5
[class*="col-"]
  padding: 0
  margin: 0
于 2014-06-14T18:52:07.633 回答
4

上述解决方案都不适合我。按照这个答案,我能够创建适合我的东西。在这里,我还使用媒体查询将其仅限于小屏幕。

@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;
    }
}
于 2015-05-20T09:05:32.160 回答
4

使用 bootstrap 3.7.7 或更低版本从 b/w 列中删除间距。

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

.no-gutter > [class*='col-'] {
        padding-right:0;
        padding-left:0;
    }
于 2018-07-31T22:51:14.410 回答
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 边距将平衡列中的排水沟。这里很好地解释了 Bootstrap 3 中的排水沟和行。

于 2015-07-08T21:56:01.697 回答
2

我想它更容易使用

margin:-30px;

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

我试过了

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

它对我有用。

于 2015-12-15T07:14:38.233 回答
2

将您的列包装在 .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;
}
于 2016-08-23T06:39:25.917 回答
1

使用 css 参考删除/自定义 Bootstrap Gutter:http: //arnique.net/web-design/58/a-quick-guide-to-changeing-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>

于 2016-12-25T20:07:24.937 回答
0

您可以创建一个用于删除边距的新类,并可以应用于要删除额外边距的元素:

.margL0 { margin-left:0 !important }

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

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

于 2013-10-24T10:13:57.757 回答
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;}
}
于 2020-01-14T10:21:25.333 回答
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
于 2015-12-13T12:16:38.767 回答
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;
}
于 2016-07-26T15:24:29.610 回答
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;
}
于 2016-02-15T05:30:29.420 回答
0

如果您使用 SASS 文件下载引导程序,您将能够编辑配置文件,其中有列边距的设置,然后保存它,这样 SASS 会计算列的新宽度

于 2016-12-26T15:03:30.710 回答
0

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

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

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

于 2017-07-25T13:55:37.693 回答
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>
于 2015-11-30T06:47:18.380 回答
-4

你可以使用叉子

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

gem "bootstrap", github: "srghma/bootstrap-rubygem-without-gutter"
于 2019-05-24T10:12:45.957 回答