国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

有關css柵格系統的故事

legendaryedu / 3055人閱讀

摘要:下面,本文將介紹幾個比較有代表性的柵格樣式庫,講述它們的簡要原理和用法正確的打開方式。雖然柵格樣式庫很棒,但它們并不是響應式設計的全部。但在這個過程中,理解各類柵格樣式庫的工作原理,正確使用它們,才能做出穩定可靠的頁面結構。

說到柵格系統grid system),你也許見過這樣的概念:

像這樣,通過固定的格子結構,來進行布局設計。這是一種設計風格,而且一直以來很廣泛地應用于網頁設計領域。這樣的風格清晰、工整,可以讓網頁具有更友好的瀏覽體驗。

而隨著響應式設計responsive design)的流行,柵格系統開始被賦予新的意義,那就是,一種響應式設計的實現方式

柵格與響應式

響應式的要點是為同一個頁面設計多種布局形態,分別適配不同屏幕尺寸的設備。一般來說,是這樣的感覺:

可以看到,一個頁面可以拆分成多個區塊來理解,而正是這些區塊共同構成了這個頁面的布局。根據不同的屏幕尺寸情況,調整這些區塊的排版,就可以實現響應式設計。另外,屏幕寬度較大的時候,區塊傾向于水平分布,而屏幕寬度較小的時候,區塊傾向于豎直堆疊。

這些方方正正的區塊是不是和柵格系統的格子挺相似?對的,為了讓響應式設計更簡單易用,于是有了很多稱為“柵格”(grid)的樣式庫。

柵格樣式庫一般是這樣做的:將頁面劃分為若干等寬的列(column),然后推薦你通過等寬列來創建響應式的頁面區塊。

雖然看起來都是這樣的思路,但不同的柵格樣式庫,在做法上卻是各有各的點子。下面,本文將介紹幾個比較有代表性的柵格樣式庫,講述它們的簡要原理和用法(正確的打開方式)。

Bootstrap中的柵格

Bootstrap[]。默認分為12列。

容器、行與列

要理解Bootstrap中的柵格,最好從掌握正確的使用方法開始。這其中有2個要點。

第1個要點是容器(container),行(row)和列(column)之間的層級關系。一個正確的寫法示例如下:

Bootstrap柵格的容器有兩種,.container(固定像素值的寬度)和.container-fluid(100%的寬度),在這里,把它們都稱為container。需要注意的是,row(.row)必須位于container的內部,column(如.col-md-6)必須位于row的內部。也就是說,container、row、column必須保持特定的層級關系,柵格系統才可以正常工作。

為什么需要這樣?查看這些元素的樣式,會發現container有15px的水平內邊距,row有-15px的水平負外邊距,column則有15px的水平內邊距。這些邊距是故意的、相互關聯的,也因此就像齒輪嚙合那樣,限定了層級結構。這些邊距其實也是Bootstrap柵格的精巧之處,如果你想進一步了解,推薦閱讀[The Subtle Magic Behind Why the Bootstrap 3 Grid Works][]。

如果要嵌套使用柵格,正確的做法是在column內直接續接row,然后再繼續接column,而不再需要container:

斷點類型

第2個要點,是不同的斷點類型的意義及其搭配。

Bootstrap柵格的column對應的類名形如.col-xx-yy是數字,表示該元素的寬度占據12列中的多少列。而xx只有特定的幾個值可供選擇,分別是xssmmdlg,它們就是斷點類型。

在Bootstrap柵格的設計中,斷點的意義是,當視口(viewport)寬度小于斷點時,column將豎直堆疊(display: block的默認表現),而當視口寬度大于或等于斷點時,column將水平排列(float的效果)。按照xssmmdlg的順序,斷點像素值依次增大,其中xs表示極小,即認為視口寬度永遠不小于xs斷點,column將始終水平浮動。

有時候,會需要將多種斷點類型組合使用,以實現更細致的響應式設計。此時不同的斷點類型之間會有怎樣的相互作用呢?

先看看Bootstrap的sass源碼是如何定義柵格的:

@include make-grid-columns;
@include make-grid(xs);
@media (min-width: $screen-sm-min) {
  @include make-grid(sm);
}
@media (min-width: $screen-md-min) {
  @include make-grid(md);
}
@media (min-width: $screen-lg-min) {
  @include make-grid(lg);
}

可以看到,用了min-width的寫法,而且斷點像素值越大的,對應代碼越靠后。所以,如果有這樣的一些元素:

1
2
3
4

那么它們應該是這樣的效果:

結合前面的源碼,可以想到,在上面這樣視口寬度由小變大的過程中,首先是保持默認的豎直堆疊,然后超過了sm的斷點,sm的樣式生效,變為一行兩列的排版,再繼續超過lg的斷點后,lg的樣式也生效,由于lg的樣式代碼定義在sm之后,所以會覆蓋掉sm的樣式,從而得到一行四列的排版。

所以,結合使用多個斷點類型,就可以引入多個斷點變化,把響應式做得更加細致。

適度使用

Bootstrap柵格雖然很強大,但也不應過度使用。例如,當你需要一個占據一整行寬度的元素時,請不要也想著讓Bootstrap柵格參和進來,加入類似.col-xs-12這樣的元素。實際上,你不需要任何柵格類,你需要的只是一個塊元素。

Foundation中的柵格

Foundation[],它和Bootstrap柵格的設計十分近似,只是在類名和結構上有所差異。Foundation柵格同樣默認12列。

行與列

類比之前Bootstrap柵格的例子,Foundation柵格的一個正確的寫法示例如下:

Foundation柵格的行用.row表示,而列由至少兩個類名組成,一是.columns.column(2種寫法完全相同,單純為了支持語法偏好)表明這是列元素,二是.medium-6這種用于表示斷點類型和對應寬度。在默認情況下,Foundation柵格的斷點類型從小到大依次是smallmediumlarge,其中small類似Bootstrap柵格的xs,也是指任意屏幕尺寸下都水平排列。

Foundation柵格沒有container,只需要row和column,因此顯得比Bootstrap柵格更簡單一些。其中row定義了最大寬度(可以認為承擔了container的部分功能),column定義了0.9375rem的水平內邊距。如果要嵌套,仍然是column內續接row,再繼續接column。

組合使用多個斷點類型,其方法也和Bootstrap柵格相同。需要注意的是,Foundation柵格的斷點值是用的em而不是px,對應的,它們轉換后的像素值也有別于Bootstrap柵格。

Block Grid

作為柵格系統的補充,Foundation還提供了另外一個叫做[Block Grid][]的柵格。不過,它并不是一個超出傳統柵格的新東西,而只是一個針對特定柵格應用場景的方法糖。

下面是一個Block Grid的示例:

其中,ulli這樣的特定標簽組合是必須的。在這個示例中,屏幕寬度從小到大的變化過程中,列元素將依次是一行兩列、一行三列、一行四列的排版方式。

可以看到,Block Grid的結構也是行和列,但只需要在行上有一個類名。和Foundation的Grid相比,它的確有一些不同。一方面,Block Grid的行并沒有定義最大寬度。另一方面,Block Grid的列一定是等寬的(畢竟li不需要任何類名)。

Toast柵格

前面介紹的兩個柵格樣式庫都來源于流行前端框架,并不是獨立的。本文接下來要介紹的[Toast][],則是一個獨立的、很有想法的柵格樣式庫。

特別的實現方式

為什么說很有想法呢?請看它的一個正確的寫法示例:

類似的,這也是一行均分兩列的排版。可以看到,Toast柵格的結構同樣是行(.grid)與列(.grid__col)。但是,不同于始終以12列為參考的模式,它可以用1-of-2這樣更為直觀的類名。事實上,這里用3-of-66-of-12等也可以,它們是相同的。

當然,這并不是Toast最特別的地方。現在,請想一下,Bootstrap及Foundation的柵格系統的column原本都是塊元素,它們是如何實現水平排列的?

對的,用的是float。但Toast是如何做的呢?它想法獨特,選用了display: inline-block;。如果你有了解過這個屬性,你應該知道inline-block的元素會彼此之間存在縫隙。Toast在選擇這個屬性的基礎之上,巧妙使用了負外邊距(例如margin-right: -.25em;),消除了縫隙對柵格column水平排列的影響。在我做了一些測試和應用后,我只能說,這個強行完成的策略要給個贊。

非Mobile First

在前面Toast柵格的示例中,并沒有類似mdmedium這樣體現斷點類型的詞。這是因為,Toast采用了“存在默認”的風格。絕大部分情況下,只需要使用形如.grid__col--x-of-y的類名。Toast已經為這個類設置了斷點(默認700px),低于這個斷點為display: block;,高于這個斷點為display: inline-block;

意外的是,不同于Bootstrap和Foundation默認取block的mobile first原則(豎直堆疊更符合小尺寸屏幕的排版要求),Toast則是把display: inline-block;放在了@media范圍之外,當做默認屬性。這應該只是風格偏好差異,就我個人而言,我還是更贊同mobile first的設計風格的。

有關mobile first的響應式設計的實現,推薦閱讀Grid。

如果要加入多個斷點變化,Toast是這樣做:

上面這段代碼的效果是,該柵格列在480px以下為block,占據滿寬,481px~700px之間為inline-block,占據1/2寬度,701px以上為inline-block,占據1/4寬度。

對柵格系統的補充

前面介紹的這些柵格樣式庫,源碼都使用Less、Sass這些css預編譯工具,因此其中的12列、斷點值、列間距等都是可配置的,只不過大部分情況下默認的就足夠使用。

雖然柵格樣式庫很棒,但它們并不是響應式設計的全部。要使同一個應用在不同屏幕尺寸的設備上都具有較好的瀏覽體驗,還有很多其他手段可用(比如在尺寸更大的屏幕上使用更大的字體),柵格系統只是方式之一。

結語

借助css柵格系統,我們可以很容易地創建響應式的頁面布局。但在這個過程中,理解各類柵格樣式庫的工作原理,正確使用它們,才能做出穩定、可靠的頁面結構。

(重新編輯自我的博客,原文地址:http://acgtofe.com/posts/2015/07/a-story-of-grid)

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/111082.html

相關文章

  • css進階

    摘要:柵格系統用于處理頁面多終端適配的問題。它表示抓取對象以后拖放到另一個位置。目前,它是標準的一部分。精簡高效的命名準則方法這篇文章發布于年月日,星期日,,歸類于相關。但是不會受到包含塊的限制,可能會溢出。 一勞永逸的搞定 flex 布局 尋根溯源話布局 一切都始于這樣一個問題:怎樣通過 CSS 簡單而優雅的實現水平、垂直同時居中。記得剛開始學習 CSS 的時候,看到 float 屬性不由...

    import. 評論0 收藏0
  • 校招進行時(四)---css基礎

    摘要:在中,使用標準盒模型描述這些矩形盒子中的每一個。這種合并外邊距的方式被稱為折疊,并且因而所結合成的外邊距稱為折疊外邊距。最常見的有簡稱和簡稱。其中列是真正顯示文檔內容的元素。同時其還支持列的偏移,即可以不從第一列開始,將某幾列作為空隙。 恩,小菜鳥又來了,上篇文章在這,話不多說,這次羅列總結一下css基礎知識,和我一樣的菜鳥可以看看。 引入方式 css的引入方式主要有以下幾種: 外...

    isLishude 評論0 收藏0
  • css柵格系統在項目中靈活運用

    摘要:前言柵格通常捆綁在各種框架中,但有時你需要自己去定制一個柵格來滿足實際的業務需要,本文聊聊柵格系統在項目中的靈活運用。 前言 css柵格通常捆綁在各種框架中,但有時你需要自己去定制一個css柵格來滿足實際的業務需要,本文聊聊css柵格系統在項目中的靈活運用。 需求 UI設計了如下布局,其中左上角橙色部分是固定的,藍色部分是動態渲染的,從前往后依次展示,有一個就顯示一塊,有二個就顯示二塊...

    summerpxy 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<