ブートストラップ-グリッドシステム

この章では、ブートストラップグリッドシステムについて説明します。

グリッドとは何ですか?

ウィキペディアによって置かれたように-

グラフィックデザインでは、グリッドは、コンテンツを構造化するために使用される一連の交差する直線(垂直、水平)線で構成される構造(通常は2次元)です。印刷デザインのレイアウトやコンテンツ構造のデザインに広く使用されています。Webデザインでは、HTMLとCSSを使用して一貫したレイアウトを迅速かつ効果的に作成することは非常に効果的な方法です。

簡単に言えば、Webデザインのグリッドはコンテンツを整理および構造化し、Webサイトのスキャンを容易にし、ユーザーの認知的負荷を軽減します。

ブートストラップグリッドシステムとは何ですか?

グリッドシステム用のブートストラップの公式ドキュメントに記載されているように-

Bootstrapには、デバイスまたはビューポートのサイズが大きくなると、最大12列まで適切にスケールアップする応答性の高いモバイルファースト流体グリッドシステムが含まれています。簡単なレイアウトオプションのための事前定義されたクラスと、よりセマンティックなレイアウトを生成するための強力なミックスインが含まれています。

上記のステートメントを理解しましょう。Bootstrap 3は、モバイルデバイスやタブレットなどの小さな画面をターゲットにすることから始まり、ラップトップやデスクトップなどの大きな画面用にコンポーネントとグリッドを「拡張」するという意味で、最初はモバイルです。

モバイルファースト戦略

  • Content

    • 最も重要なものを決定します。
  • Layout

    • 最初に小さい幅に設計します。
    • 最初にベースCSSアドレスモバイルデバイス。メディアクエリは、タブレット、デスクトップのアドレスです。
  • Progressive Enhancement

    • 画面サイズが大きくなるにつれて要素を追加します。

ブートストラップグリッドシステムの動作

グリッドシステムは、コンテンツを格納する一連の行と列を介してページレイアウトを作成するために使用されます。ブートストラップグリッドシステムの仕組みは次のとおりです-

  • 行は、内に配置する必要があります .container 適切な配置とパディングのためのクラス。

  • 行を使用して、列の水平グループを作成します。

  • コンテンツは列内に配置する必要があり、列のみが行の直接の子になることができます。

  • 次のような事前定義されたグリッドクラス .row and .col-xs-4グリッドレイアウトをすばやく作成するために使用できます。LESSミックスインは、よりセマンティックなレイアウトにも使用できます。

  • 列は、パディングを介してガター(列の内容間のギャップ)を作成します。そのパディングは、最初と最後の列の行で負のマージンを介してオフセットされます。.rows

  • グリッド列は、スパンする12個の使用可能な列の数を指定することによって作成されます。たとえば、3つの等しい列は3つを使用します.col-xs-4

メディアクエリ

メディアクエリは、「条件付きCSSルール」の非常に凝った用語です。記載されている特定の条件に基づいて、CSSを適用するだけです。これらの条件が満たされると、スタイルが適用されます。

Bootstrapのメディアクエリを使用すると、ビューポートサイズに基づいてコンテンツを移動、表示、および非表示にできます。以下のメディアクエリは、ブートストラップグリッドシステムに主要なブレークポイントを作成するためにLESSファイルで使用されます。

/* Extra small devices (phones, less than 768px) */
/* No media query since this is the default in Bootstrap */

/* Small devices (tablets, 768px and up) */
@media (min-width: @screen-sm-min) { ... }

/* Medium devices (desktops, 992px and up) */
@media (min-width: @screen-md-min) { ... }

/* Large devices (large desktops, 1200px and up) */
@media (min-width: @screen-lg-min) { ... }

時折、これらは以下を含むように拡張されます max-width CSSをより狭いデバイスのセットに制限します。

@media (max-width: @screen-xs-max) { ... }
@media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) { ... }
@media (min-width: @screen-md-min) and (max-width: @screen-md-max) { ... }
@media (min-width: @screen-lg-min) { ... }

メディアクエリには、デバイス仕様とサイズルールの2つの部分があります。上記の場合、次のルールが設定されます-

この行を考えてみましょう-

@media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) { ... }

どんなにどのような種類で、すべてのデバイスでは最小幅:画面-SM-分@画面の幅がより小さくなる場合には、画面-SM-MAX @そして何かをします

グリッドオプション

次の表は、Bootstrapグリッドシステムが複数のデバイス間でどのように機能するかをまとめたものです。

超小型デバイス電話(<768px) 小型デバイスタブレット(≥768px) 中型デバイスデスクトップ(992px以上) 大型デバイスデスクトップ(≥1200px)
グリッドの動作 常に水平 ブレークポイントの上の水平方向に折りたたまれて開始 ブレークポイントの上の水平方向に折りたたまれて開始 ブレークポイントの上の水平方向に折りたたまれて開始
コンテナの最大幅 なし(自動) 750px 970px 1170px
クラスプレフィックス .col-xs- .col-sm- .col-md- .col-lg-
列数 12 12 12 12
最大列幅 自動 60px 78px 95px
側溝幅

30px

(列の両側に15px)

30px

(列の両側に15px)

30px

(列の両側に15px)

30px

(列の両側に15px)

必要な はい はい はい はい
オフセット はい はい はい はい
列の順序 はい はい はい はい

基本的なグリッド構造

以下は、ブートストラップグリッドの基本構造です。

<div class = "container">

   <div class = "row">
      <div class = "col-*-*"></div>
      <div class = "col-*-*"></div>
   </div>
   
   <div class = "row">...</div>
	
</div>

<div class = "container">
   ....
</div>

いくつかの簡単なグリッドの例を見てみましょう-

  • 例-スタックから水平

  • 例-中型および大型デバイス

  • 例-モバイル、タブレット、デスクトップ

レスポンシブカラムのリセット

利用可能なグリッドの4つの層があると、特定のブレークポイントで、一方が他方よりも高いため、列が完全にクリアされないという問題が発生することになります。これを修正するには、クラスの組み合わせを使用します.clearfix次の例に示すように、レスポンシブユーティリティクラス-

<div class = "container">
   <div class = "row" >
   
      <div class = "col-xs-6 col-sm-3" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
      </div>
      
      <div class = "col-xs-6 col-sm-3" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do 
            eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut 
            enim ad minim veniam, quis nostrud exercitation ullamco laboris 
            nisi ut aliquip ex ea commodo consequat.</p>
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do 
            eiusmod tempor incididunt ut.</p>
      </div>

      <div class = "clearfix visible-xs"></div>
      
      <div class = "col-xs-6 col-sm-3" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Ut enim ad minim veniam, quis nostrud exercitation ullamco 
            laboris nisi ut aliquip ex ea commodo consequat.</p>
      </div>
      
      <div class = "col-xs-6 col-sm-3" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do 
            eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut 
            enim ad minim</p>
      </div>
      
   </div>
</div>

これにより、次の結果が生成されます-

この例の望ましい結果については、ビューポートのサイズを変更するか、携帯電話で確認してください。

オフセット列

オフセットは、より特殊なレイアウトに役立つ機能です。たとえば、列を押して間隔を広げるために使用できます。ザ・.col-xs = * クラスはオフセットをサポートしていませんが、空のセルを使用して簡単に複製できます。

大型ディスプレイでオフセットを使用するには、 .col-md-offset-*クラス。これらのクラスは、列の左マージンを次のように増やします。* ここで列 * の範囲 111

次の例では、<div class = "col-md-6"> .. </ div>があり、クラスを使用してこれを中央に配置します .col-md-offset-3

<div class = "container">

   <h1>Hello, world!</h1>

   <div class = "row" >
      <div class = "col-xs-6 col-md-offset-3" style = "background-color: #dedef8; 
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
      </div>

   </div>
	
</div>

これにより、次の結果が生成されます-

ネスト列

デフォルトのグリッドでコンテンツをネストするには、新しいグリッドを追加します .row とのセット .col-md-* 既存の列内の列 .col-md-*カラム。ネストされた行には、合計12個の列のセットを含める必要があります。

次の例では、レイアウトに2つの列があり、2番目の列は2行にわたって4つのボックスに分割されています。

<div class = "container">
   <h1>Hello, world!</h1>

   <div class = "row">

      <div class = "col-md-3" style = "background-color: #dedef8; 
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <h4>First Column</h4>
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
      </div>

      <div class = "col-md-9" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <h4>Second Column- Split into 4 boxes</h4>
         <div class = "row">
            
            <div class = "col-md-6" style = "background-color: #B18904;
               box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
               
               <p>Consectetur art party Tonx culpa semiotics. 
                  Pinterest assumenda minim organic quis.</p>
            </div>
            
            <div class = "col-md-6" style = "background-color: #B18904;
               box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
               
               <p>sed do eiusmod tempor incididunt ut labore et dolore magna 
                  aliqua. Ut enim ad minim veniam, quis nostrud exercitation 
                  ullamco laboris nisi ut aliquip ex ea commodo consequat.</p>
            </div>
				
         </div>

         <div class = "row">
			
            <div class = "col-md-6" style = "background-color: #B18904;
               box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
               
               <p>quis nostrud exercitation ullamco laboris nisi ut aliquip 
                  ex ea commodo consequat.</p>
            </div>   
            
            <div class = "col-md-6" style = "background-color: #B18904;
               box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
               
               <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, 
                  sed do eiusmod tempor incididunt ut labore et dolore magna 
                  aliqua. Ut enim ad minim.</p>
            </div>
				
         </div>

      </div>

   </div>
	
</div>

これにより、次の結果が生成されます-

列の順序

Bootstrapグリッドシステムのもう1つの優れた機能は、列を順番に簡単に記述して、別の列に表示できることです。組み込みのグリッド列の順序は、次のコマンドで簡単に変更できます。.col-md-push-* そして .col-md-pull-* 修飾子クラスここで * の範囲 111

次の例では、2列のレイアウトがあり、左側の列が最も狭く、サイドバーとして機能します。を使用してこれらの列の順序を入れ替えます.col-md-push-* そして .col-md-pull-* クラス。

<div class = "container">
   <h1>Hello, world!</h1>
   
   <div class = "row">
      <p>Before Ordering</p>
      
      <div class = "col-md-4" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         I am on left
      </div>
      
      <div class = "col-md-8" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         I am on right
      </div>
      
   </div>
	
   <br>
   
   <div class = "row">
      <p>After Ordering</p>
      
      <div class = "col-md-4 col-md-push-8" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         I was on left
      </div>
      
      <div class = "col-md-8 col-md-pull-4" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         I was on right
      </div>
		
   </div>

</div>

これにより、次の結果が生成されます-