問題:
ブートストラップ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>
希望の出力:
現在このコードは2列の左右にパディング/マージンを追加します。側面の余分なスペースを削除するために欠けているものは何だろうか。
お知らせ:
"col-md-4"を削除すると、両方の列が100%に拡大されますが、それらは互いに隣り合っているようにします。
.row
ではなく、通常2つの列を折り返すために .col-md-12
を使用します。これは別の列を囲む列です。 Afternl、 .row
は、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;
}
私はいつもこのスタイルを私のBootstrap LESS/SASSに追加します。
.row-no-padding {
[class*="col-"] {
padding-left: 0 !important;
padding-right: 0 !important;
}
}
それからHTMLであなたは書くことができます:
<div class="row row-no-padding">
子列のみをターゲットにしたい場合は、子セレクタを使用できます(Thanks 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;
}
}
}
小型デバイスを上向きにサポートしたい場合は、メディアクエリの最大幅部分を削除できます。
ページの幅を広げてページの他の部分とは異なるようにするため、列の余白を減らしてもうまくいきません(navbar)。あなたは同様に行のマイナスのマージンを減らす必要があります。 @martinedwardsのLESSの例を取ります。
.row-no-padding {
margin-left: 0;
margin-right: 0;
[class*="col-"] {
padding-left: 0 !important;
padding-right: 0 !important;
}
}
特に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できます。
単純に "no-padding" を追加します。これはブートストラップ3に組み込まれたクラスです。
今後Bootstrap4でのみ入手可能
<div class="p-0 m-0">
</div>
注:.p-0と.m-0はすでにbootstrap.cssを追加しました
もう1つの解決策は、ブートストラップをその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
を含めます。これで終わりです。私のようにすでにブートストラップソースを使用しているのであれば、追加のルールを定義する代わりになるかもしれません。
ブートストラップ4 これを行うためのネイティブクラスがあります。クラス.no-gutters
を親.row
に追加します
[class*="col-"]
padding: 0
margin: 0
上記の解決策のどれも私のために完全には機能しませんでした。 この答えに続いて 私は私のために働く何かを作成することができました。ここでも私はメディアクエリを使ってこれを小さなスクリーンに限定しています。
@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;
}
}
ブートストラップ4には、行要素に追加できるクラス.no-guttersがあります。
<div class="container-fluid">
<div class="row no-gutters">
<div class="col-md-12">
[YOUR CONTENT HERE]
</div>
</div>
</div>
参照: http://getbootstrap.com/docs/4.0/layout/grid/#grid-options
ただ使うほうが簡単だと思います
margin:-30px;
ブートストラップによって設定された元の値を上書きします。
私はもう試した
margin: 0px -30px 0px -30px;
そしてそれは私のために働いた。
<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のガターと行について。
Bootstrap 3は、バージョン 3.4.0 以降、パディングを削除する公式な方法があります:クラス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>
CSSリファレンスを使用してBootstrap Gutterを削除/カスタマイズします。 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>
列を.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;
}
ブートストラップ3.7.7以下を使用して、白黒の列からスペースを取り除きます。
.no-Gutterはあなたの行に追加できるカスタムクラスです
.no-Gutter > [class*='col-'] {
padding-right:0;
padding-left:0;
}
SASSファイルと一緒にブートストラップをダウンロードすると、カラムのマージンの設定がある設定ファイルを編集して保存することができます。その場合、SASSはカラムの新しい幅を計算します。
余白を削除するための新しいクラスを作成して、余白を削除する要素に適用できます。
.margL0 { margin-left:0 !important }
!important :デフォルトのマージンを削除したり、現在のマージン値を上書きしたりするのに役立ちます。
左側から余白を削除したいdivに適用します。
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;
}
ブートストラップグリッドシステムをカスタマイズして、カスタムレスポンシブグリッドを定義できます。
次のガター幅のデフォルト値を@grid-Gutter-width = 30px
から@grid-Gutter-width = 0px
に変更します。
(溝の幅は列間のパディングです。左右に半分に分割されます。)
ときどき、列に必要な余白をなくすことがあります。彼らは結局互いに付き合うことになります。それを防ぐために、次のようにクラスを更新することができます。
<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;
}
<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>
ブートストラップを使用して列のマージンと余白を管理するためのLess Mixinを作成できます。
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
あなたはフォークを使うことができます
gem "bootstrap", github: "srghma/bootstrap-rubygem-without-Gutter"