Bootstrap - Sistem Grid

Pada bab ini kita akan membahas tentang Bootstrap Grid System.

Apa itu Grid?

Seperti yang dikatakan oleh wiki -

Dalam desain grafis, kisi adalah struktur (biasanya dua dimensi) yang terdiri dari serangkaian garis lurus (vertikal, horizontal) berpotongan yang digunakan untuk menyusun konten. Ini banyak digunakan untuk merancang tata letak dan struktur konten dalam desain cetak. Dalam desain web, ini adalah metode yang sangat efektif untuk membuat tata letak yang konsisten dengan cepat dan efektif menggunakan HTML dan CSS.

Sederhananya, kisi dalam desain web mengatur dan menyusun konten, membuat situs web mudah dipindai dan mengurangi beban kognitif pada pengguna.

Apa itu Sistem Bootstrap Grid?

Seperti yang dimasukkan oleh dokumentasi resmi Bootstrap untuk sistem grid -

Bootstrap menyertakan sistem grid fluida pertama seluler yang responsif yang menskalakan dengan tepat hingga 12 kolom saat perangkat atau ukuran viewport bertambah. Ini mencakup kelas yang telah ditentukan untuk opsi tata letak yang mudah, serta mixin yang kuat untuk menghasilkan lebih banyak tata letak semantik.

Mari kita pahami pernyataan di atas. Bootstrap 3 adalah seluler pertama dalam arti bahwa kode untuk Bootstrap sekarang dimulai dengan menargetkan layar yang lebih kecil seperti perangkat seluler, tablet, dan kemudian "memperluas" komponen dan kisi untuk layar yang lebih besar seperti laptop, desktop.

Strategi Pertama Seluler

  • Content

    • Tentukan apa yang paling penting.
  • Layout

    • Rancang dulu lebar yang lebih kecil.
    • Basis alamat CSS perangkat seluler terlebih dahulu; alamat media queries untuk tablet, desktop.
  • Progressive Enhancement

    • Tambahkan elemen saat ukuran layar meningkat.

Bekerja dari Sistem Grid Bootstrap

Sistem kisi digunakan untuk membuat tata letak halaman melalui serangkaian baris dan kolom yang menampung konten Anda. Inilah cara kerja sistem grid Bootstrap -

  • Baris harus ditempatkan dalam a .container kelas untuk perataan dan bantalan yang tepat.

  • Gunakan baris untuk membuat kelompok kolom horizontal.

  • Konten harus ditempatkan dalam kolom, dan hanya kolom yang boleh menjadi turunan langsung dari baris.

  • Kelas grid standar seperti .row and .col-xs-4tersedia untuk membuat tata letak kisi dengan cepat. Mixin LESS juga dapat digunakan untuk tata letak yang lebih semantik.

  • Kolom membuat talang (celah antara konten kolom) melalui padding. Padding tersebut diimbangi dalam baris untuk kolom pertama dan terakhir melalui margin negatif pada.rows.

  • Kolom kisi dibuat dengan menentukan jumlah dua belas kolom yang tersedia yang ingin Anda bentangkan. Misalnya, tiga kolom yang sama akan menggunakan tiga.col-xs-4.

Kueri Media

Kueri media adalah istilah yang sangat bagus untuk "aturan CSS bersyarat". Ini hanya menerapkan beberapa CSS, berdasarkan kondisi tertentu yang ditetapkan. Jika kondisi tersebut terpenuhi, gaya diterapkan.

Media Queries di Bootstrap memungkinkan Anda untuk memindahkan, menampilkan dan menyembunyikan konten berdasarkan ukuran viewport. Media queries berikut digunakan dalam file LESS untuk membuat breakpoint kunci dalam sistem grid Bootstrap.

/* 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) { ... }

Kadang-kadang ini diperluas untuk mencakup a max-width untuk membatasi CSS ke perangkat yang lebih sempit.

@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) { ... }

Kueri media memiliki dua bagian, spesifikasi perangkat dan kemudian aturan ukuran. Dalam kasus di atas, aturan berikut ditetapkan -

Mari kita pertimbangkan baris ini -

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

Untuk semua perangkat, apa pun jenisnya dengan min-width: @ screen-sm-min jika lebar layar menjadi lebih kecil dari @ screen-sm-max , lakukan sesuatu .

Opsi kisi

Tabel berikut merangkum aspek-aspek bagaimana sistem grid Bootstrap bekerja di beberapa perangkat -

Ponsel perangkat ekstra kecil (<768px) Tablet perangkat kecil (≥768px) Desktop perangkat sedang (≥992px) Desktop perangkat besar (≥1200px)
Perilaku grid Horisontal setiap saat Diciutkan untuk memulai, horizontal di atas breakpoint Diciutkan untuk memulai, horizontal di atas breakpoint Diciutkan untuk memulai, horizontal di atas breakpoint
Lebar wadah maks Tidak ada (otomatis) 750px 970px 1170px
Awalan kelas .col-xs- .col-sm- .col-md- .col-lg-
# kolom 12 12 12 12
Lebar kolom maks Mobil 60px 78px 95px
lebar selokan

30px

(15px di setiap sisi kolom)

30px

(15px di setiap sisi kolom)

30px

(15px di setiap sisi kolom)

30px

(15px di setiap sisi kolom)

Nestable Iya Iya Iya Iya
Offset Iya Iya Iya Iya
Urutan kolom Iya Iya Iya Iya

Struktur Grid Dasar

Berikut ini adalah struktur dasar dari Bootstrap grid -

<div class = "container">

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

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

Mari kita lihat beberapa contoh kisi sederhana -

  • Contoh - Ditumpuk ke horizontal

  • Contoh - Perangkat Sedang dan Besar

  • Contoh - Ponsel, tablet, desktop

Penyetelan ulang kolom responsif

Dengan empat tingkatan kisi yang tersedia, Anda pasti akan mengalami masalah di mana pada breakpoint tertentu, kolom tidak cukup jelas karena salah satunya lebih tinggi dari yang lain. Untuk mengatasinya, gunakan kombinasi kelas.clearfixdan kelas utilitas responsif seperti yang ditunjukkan pada contoh berikut -

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

Ini akan menghasilkan hasil sebagai berikut -

Ubah ukuran viewport Anda atau periksa di ponsel Anda untuk mendapatkan hasil yang diinginkan dari contoh ini.

Kolom Offset

Offset adalah fitur yang berguna untuk tata letak yang lebih khusus. Mereka dapat digunakan untuk mendorong kolom agar lebih banyak spasi, (misalnya). Itu.col-xs = * class tidak mendukung offset, tetapi mudah direplikasi dengan menggunakan sel kosong.

Untuk menggunakan offset pada layar besar, gunakan .col-md-offset-*kelas. Kelas-kelas ini meningkatkan margin kiri kolom sebesar* kolom dimana * berkisar dari 1 untuk 11.

Dalam contoh berikut, kami memiliki <div class = "col-md-6"> .. </div>, Kami akan memusatkan ini menggunakan kelas .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>

Ini akan menghasilkan hasil sebagai berikut -

Kolom bersarang

Untuk menumpuk konten Anda dengan kisi default, tambahkan yang baru .row dan set .col-md-* kolom dalam yang ada .col-md-*kolom. Baris bersarang harus menyertakan satu set kolom yang berjumlah 12.

Dalam contoh berikut, tata letak memiliki dua kolom, dengan kolom kedua dipisahkan menjadi empat kotak dalam dua baris.

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

Ini akan menghasilkan hasil sebagai berikut -

Penyusunan Kolom

Fitur bagus lainnya dari sistem grid Bootstrap adalah Anda dapat dengan mudah menulis kolom secara berurutan, dan menampilkannya di kolom lain. Anda dapat dengan mudah mengubah urutan kolom kisi bawaan dengan.col-md-push-* dan .col-md-pull-* kelas pengubah di mana * berkisar dari 1 untuk 11.

Dalam contoh berikut kami memiliki tata letak dua kolom dengan kolom kiri menjadi yang tersempit dan bertindak sebagai sidebar. Kami akan menukar urutan kolom ini menggunakan.col-md-push-* dan .col-md-pull-* kelas.

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

Ini akan menghasilkan hasil sebagai berikut -