Bootstrap 網(wǎng)格系統(tǒng)布局詳解
Bootstrap 提供了一套響應式、移動設(shè)備優(yōu)先的流式網(wǎng)格系統(tǒng)(Grid System),隨著屏幕或視口(viewport)尺寸的增加,系統(tǒng)會自動分為最多12列。
一、什么是網(wǎng)格(Grid)?
在平面設(shè)計中,網(wǎng)格是一種由一系列用于組織內(nèi)容的相交的直線(垂直的、水平的)組成的結(jié)構(gòu)(通常是二維的)。它廣泛應用于打印設(shè)計中的設(shè)計布局和內(nèi)容結(jié)構(gòu)。在網(wǎng)頁設(shè)計中,它是一種用于快速創(chuàng)建一致的布局和有效地使用 HTML 和 CSS 的方法。
一句話概括:網(wǎng)頁設(shè)計中的網(wǎng)格用于組織內(nèi)容,讓網(wǎng)站易于瀏覽,并降低用戶端的負載。
二、什么是Bootstrap網(wǎng)格系統(tǒng)(Grid System)?
Bootstrap 包含了一個 響應式的、移動設(shè)備優(yōu)先的、不固定的網(wǎng)格系統(tǒng) ,可以隨著設(shè)備或視口大小的增加而適當?shù)財U展到 12 列。它包含了用于簡單的布局選項的預定義類,也包含了用于生成更多語義布局的功能強大的混合類。
三、網(wǎng)格系統(tǒng)工作原理
網(wǎng)格系統(tǒng)通過一系列包含內(nèi)容的行和列來創(chuàng)建頁面布局。下面列出了 Bootstrap 網(wǎng)格系統(tǒng)是如何工作的:
•行必須放置在 .container class 內(nèi),以便獲得適當?shù)膶R(alignment)和內(nèi)邊距(padding)。
•使用行row來創(chuàng)建列的水平組。
•內(nèi)容應該放置在列內(nèi), 且唯有列可以是行的直接子元素 。
•預定義的網(wǎng)格類,比如 .row 和 .col-xs-4 ,可用于快速創(chuàng)建網(wǎng)格布局。LESS 混合類可用于更多語義布局。
•列通過內(nèi)邊距(padding)來創(chuàng)建列內(nèi)容之間的間隙。該內(nèi)邊距是通過 .rows 上的外邊距(margin)取負,表示第一列和最后一列的行偏移。
•網(wǎng)格系統(tǒng)是通過指定您想要橫跨的十二個可用的列來創(chuàng)建的。例如,要創(chuàng)建三個相等的列,則使用三個 .col-xs-4。
下面是 Bootstrap 基本的網(wǎng)格結(jié)構(gòu):
<div class="container"> <div class="row"> <div class="col-*-*"></div> <div class="col-*-*"></div> </div> <div class="row">...</div> </div> <div class="container"> ... </div>
注意:列 <div class="col-*-*"></div> 必須放在 <div class="row"> 行元素下,且行元素里邊只能包含列子元素,不能跟其他的子標簽元素,否則,布局樣式會亂掉。
四、布局實戰(zhàn)
代碼:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Bootstrap 實例 - 布局偏移列-@corwien</title> <link rel="stylesheet" > <script src="https://cdn.static.runoob.com/libs/jquery/2.1.1/jquery.min.js"></script> <script src="https://cdn.static.runoob.com/libs/bootstrap/3.3.7/js/bootstrap.min.js"></script> </head> <body style="margin:50px;background:gray;"> <div class="container" style="background:white;"> <div class="row" > <div class="col-md-8 col-md-offset-1"> <div style="background:pink; height:50px;">區(qū)塊一 (col-md-8 col-md-offset-1)</div> </div> <div class="col-md-3"> <div style="background:orange; height:50px;">區(qū)塊二 (col-md-3)</div> </div> <div class="col-md-8 col-md-offset-1"> <div style="background:green; height:50px;">區(qū)塊三 (col-md-8 col-md-offset-1)</div> </div> <div class="col-md-4"> <div style="background:red; height:50px;">區(qū)塊四 (col-md-4)</div> </div> <div class="col-md-12"> <div style="background:yellow; height:50px;">區(qū)塊五(col-md-12)</div> </div> <div class="col-md-3"> <div style="background:purple; height:50px;">區(qū)塊六(col-md-3)</div> </div> <div class="col-md-6"> <div style="background:beige; height:50px;">區(qū)塊七(col-md-6)</div> </div> <div class="col-md-3"> <div style="background:olive; height:50px;">區(qū)塊八(col-md-3)</div> </div> </div> </div> </body> </html>
說明:灰色區(qū)域為body, 白色區(qū)域內(nèi)為container容器。
注意:這里要特別注意區(qū)塊一、區(qū)塊二為在同一行,而區(qū)塊三、和區(qū)塊四在不同行,為什么呢?因為列元素為行內(nèi)元素,如果一行沒有夠12列,則下邊的區(qū)塊元素會和它上邊的區(qū)塊列加起來小于或等于12,則會排在同一行,如果加起來大于12,則會排在下一列,如區(qū)塊一和區(qū)塊二兩個列加起來等于12,則剛好能排在同一行,而區(qū)塊三、四兩個列加起來為13,超過一行最大顯示列數(shù)12,自然就排在另一行了。
以上所述是小編給大家介紹的Bootstrap 網(wǎng)格系統(tǒng)布局,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
相關(guān)文章
JavaScript控制網(wǎng)頁層收起和展開效果的方法
這篇文章主要介紹了JavaScript控制網(wǎng)頁層收起和展開效果的方法,涉及javascript操作網(wǎng)頁元素動態(tài)效果的技巧,非常具有實用價值,需要的朋友可以參考下2015-04-04
Javascript實現(xiàn)Vue跨組件通信的方法詳解
這篇文章主要為大家詳細介紹了Vue的跨組件通信,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03
ng-options和ng-checked在表單中的高級運用(推薦)
AngularJS是當前非常的流行的前端框架,它的語法糖非常多,也極大的方便了前端開發(fā)者。這篇文章主要介紹了ng-options和ng-checked在表單中的高級運用,需要的朋友可以參考下2017-01-01
js調(diào)試工具 Javascript Debug Toolkit 2.0.0版本發(fā)布
Javascript Debug Toolkit是一個可以跨瀏覽器調(diào)試javascript的開源項目,支持在IE,FIREFOX,SAFARI,CHROME等瀏覽器中調(diào)試javascript。2.0.0版本做了較大變動,增加以下功能2008-12-12
原生js實現(xiàn)手風琴功能(支持橫縱向調(diào)用)
本文主要介紹了原生js實現(xiàn)手風琴功能(支持橫縱向調(diào)用)的示例代碼。具有一定的參考價值,下面跟著小編一起來看下吧2017-01-01
使用JavaScript獲取Request中參數(shù)的值方法
下面小編就為大家?guī)硪黄褂肑avaScript獲取Request中參數(shù)的值方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09

