부트 스트랩-그리드 시스템

이 장에서는 부트 스트랩 그리드 시스템에 대해 설명합니다.

그리드 란?

Wikepedia에 의해-

그래픽 디자인에서 그리드는 콘텐츠를 구성하는 데 사용되는 일련의 교차 직선 (수직, 수평)으로 구성된 구조 (보통 2 차원)입니다. 인쇄 디자인에서 레이아웃 및 콘텐츠 구조를 디자인하는 데 널리 사용됩니다. 웹 디자인에서 HTML과 CSS를 사용하여 빠르고 효과적으로 일관된 레이아웃을 만드는 매우 효과적인 방법입니다.

간단히 말해서 웹 디자인의 그리드는 콘텐츠를 구성하고 구성하며 웹 사이트를 쉽게 검색하고 사용자의인지 부하를 줄여줍니다.

부트 스트랩 그리드 시스템이란?

그리드 시스템 용 부트 스트랩의 공식 문서에 따르면-

Bootstrap에는 장치 또는 뷰포트 크기가 증가함에 따라 최대 12 개 열까지 적절하게 확장되는 반응 형 모바일 퍼스트 유체 그리드 시스템이 포함되어 있습니다. 손쉬운 레이아웃 옵션을위한 사전 정의 된 클래스와 더 시맨틱 한 레이아웃을 생성하기위한 강력한 믹스 인이 포함되어 있습니다.

위의 진술을 이해합시다. Bootstrap 3은 이제 모바일 장치, 태블릿과 같은 작은 화면을 대상으로 시작한 다음 노트북, 데스크톱과 같은 더 큰 화면을 위해 구성 요소와 그리드를 "확장"하는 것으로 Bootstrap의 코드가 시작된다는 점에서 모바일 우선입니다.

모바일 우선 전략

  • Content

    • 가장 중요한 것을 결정하십시오.
  • Layout

    • 먼저 더 작은 너비로 디자인하십시오.
    • 기본 CSS 주소는 먼저 모바일 장치입니다. 미디어는 태블릿, 데스크톱에 대한 주소를 쿼리합니다.
  • Progressive Enhancement

    • 화면 크기가 커지면 요소를 추가합니다.

부트 스트랩 그리드 시스템의 작동

그리드 시스템은 콘텐츠를 보관하는 일련의 행과 열을 통해 페이지 레이아웃을 만드는 데 사용됩니다. 부트 스트랩 그리드 시스템이 작동하는 방법은 다음과 같습니다.

  • 행은 .container 적절한 정렬 및 패딩을위한 클래스.

  • 행을 사용하여 가로 열 그룹을 만듭니다.

  • 콘텐츠는 열 내에 배치되어야하며 열만 행의 직계 자식이 될 수 있습니다.

  • 다음과 같은 미리 정의 된 그리드 클래스 .row and .col-xs-4그리드 레이아웃을 빠르게 만드는 데 사용할 수 있습니다. LESS 믹스 인은 더 의미있는 레이아웃에도 사용할 수 있습니다.

  • 열은 패딩을 통해 거터 (열 내용 사이의 간격)를 만듭니다. 해당 패딩은 음의 여백을 통해 첫 번째 및 마지막 열의 행에서 오프셋됩니다..rows.

  • 그리드 열은 확장하려는 사용 가능한 열 수를 12 개 지정하여 생성됩니다. 예를 들어, 세 개의 동일한 열은 세 개의.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) { ... }

미디어 쿼리에는 장치 사양과 크기 규칙의 두 부분이 있습니다. 위의 경우 다음 규칙이 설정됩니다.

이 라인을 고려해 보겠습니다.

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

상관없이 어떤 종류의 모든 장치의 최소 폭 : 화면-SM-분 @ 화면의 폭보다 작아지는 경우 화면-SM-최대 @ , 다음 일을 할 .

그리드 옵션

다음 표는 부트 스트랩 그리드 시스템이 여러 장치에서 작동하는 방식을 요약 한 것입니다.

초소형 장치 전화 (<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)

중첩 가능
오프셋
컬럼 순서

기본 그리드 구조

다음은 Bootstrap 그리드의 기본 구조입니다.

<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-*클래스. 이 클래스는 열의 왼쪽 여백을 다음과 같이 늘립니다.* 열 어디에 * 범위 1 ...에 11.

다음 예제에서는 <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 개를 더하는 열 집합이 포함되어야합니다.

다음 예에서 레이아웃에는 두 개의 열이 있으며 두 번째 열은 두 행에 걸쳐 네 개의 상자로 분할됩니다.

<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 그리드 시스템의 또 다른 멋진 기능은 순서대로 열을 쉽게 작성하고 다른 열에 표시 할 수 있다는 것입니다. 내장 된 그리드 기둥의 순서를 쉽게 변경할 수 있습니다..col-md-push-*.col-md-pull-* 수정 자 클래스 * 범위 1 ...에 11.

다음 예에서는 왼쪽 열이 가장 좁고 사이드 바 역할을하는 두 개의 열 레이아웃이 있습니다. 다음을 사용하여 이러한 열의 순서를 바꿉니다..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>

이것은 다음 결과를 생성합니다-