節選翻譯自The Subtle Magic Behind Why the Bootstrap 3 Grid Worksbootstrap
從接觸 Bootstrap 已經有很長時間了,給人的感受是快速,簡單,易上手,其中柵格系統是一個亮點:瀏覽器
一直感受像 CSS 柵格系統之類的東西拿過來用就行了,不用深究背後的原理。直到有一天你發現簡單的套用在稍複雜的頁面上出現問題,間隔啊,內外邊距啊,哪都不對勁兒。app
固然會有這樣的過程,而後隨着知識的積累,能夠去讀一些 Bootstrap 的源碼,結合文檔會發現一些不是很理解的地方:ui
Rows must be placed within a .container (fixed-width) or .container-fluid (full-width) for proper alignment and padding.spa
「行(row)」必須包含在 .container (固定寬度)或 .container-fluid (100% 寬度)中,以便爲其賦予合適的排列(aligment)和內補(padding)。翻譯
Container 有兩個做用:blog
在隨時可能的寬度變化(響應式)中提供寬度限制。當頁面寬度變化,container 的寬度也隨之變化。而且其中的 column 的寬度是基於百分比,因此他們的值不須要變化。圖片
提供一個水平方向的 padding,使其內部的內容不會接觸到瀏覽器的邊界,大小爲15px,就是圖片中粉紅色的部分,做用會在下面說。文檔
注意,不須要也不該該在 container 中嵌套另外一個 container。
get
Row 是 column 直接存在的容器,按照文檔描述 row 中最多可有12個 column,不過能夠經過 nesting 的方式靈活擴展。同時做爲都是左浮動的 column 的 wrapper,自帶 clearfix 的性質。
同時 row 還有一個很特殊的地方,就是左右各有 -15px 的 margin,就是圖片中的藍色部分。這樣也就抵消了上面提到的 container 中15px的 padding,那麼爲何要這麼折騰呢?接着看往下讀。
注意:千萬記住要把 row 放到 container 的內部,這樣才能保證正常。
注意啦,每一個column 也會有15px的水平方向的 padding,也就是圖片中黃色的部分,唉,先別急,會明白的。還記得上面提到的 row 的做用嗎,colunmn 只能在 row 中生存,因爲 row 的 margin 爲-15px,那麼位於兩邊的 column 就碰到了 container 的邊界。可是 colunmn 自己又有 15px 的 padding 使得它其中的內容並不會碰到 container,同時 不一樣column的內容之間就有了30px的槽。結合圖片看一下就一目瞭然了。
注意:必定要把 column 放到 row 裏使用。
當把上面一系列的 container, row, column 都設置好,就能夠經過 nesting 擴展它的柵格系統了,也就是在 column 中直接嵌套 row,而不須要再套一層 container:
還記得 container 和 column 都有15px的 padding 嗎,當 nesting 的時候 column 的做用也至關於 container 了,這樣就能夠實現任意的嵌套了。
這正是 Bootstrap 的柵格系統的最巧妙的地方!