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 -