摘要:網格單元格網格單元格是指四條網格線之間的空間。所以它是最小的單位,就像表格中的單元格。圖中突出顯示的網格區域是行線和列線之間的區域,其主要包括了四個網格單元格。
CSS Grid現在已經被W3C納入到CSS3的一個布局模塊當中,被稱為CSS Grid Layout Module。而我們較為熟悉的還是將其想像成網格或者柵格,也就是早期的960gs。不管是網格還是柵格或者現在的CSS Grid Layout Module,我想掌握這些技術對于我們將來在Web項目中實現布局只有好處沒有壞處。那么從今天開始我將和大家一起探討CSS中的網格布局。
為什么我們需要網格布局?在我們的Web內容中,可以將其分割成很多個內容塊,而這些內容塊都占據自己的區域(regions),可以將這些區域想像成是一個虛擬的網格。到目前為止,在一個模板中使用不同的結構標簽,使用多個浮動和手動計算實現一個布局。這對于Web前端人員來說,這是一件痛苦之事。而網格布局將讓你擺脫這樣的困局,讓你的布局方法變得非常簡單與清晰。
網格布局給了我們一種方法——創建的結構與使用表格(table)布局并沒有什么不同。然而,他是在CSS中實現而不是在HTML中實現,同時還可以依賴于媒體查詢根據不同的上下文得新定義布局。這對于喜歡響應式設計的同學來說是一個絕對利好的消息。因為你不在需要再擔心你的HTML結構而影響你的布局。
網格布局還可以讓我們擺脫現在布局中存在的文檔流限制,換句話說,你的結構不需要根據設計稿從上往上布置了。這也意味著您可以自由地更改頁面元素位置。這最適合你在不同的斷點位置實現你最需要的布局,而不再需要為響應你的設計而擔心HTML結構的問題。
什么是CSS Grid Layout?CSS Grid Layout是CSS為布局新增的一個模塊。網格布局特性主要是針對于Web應用程序的開發者。可以用這個模塊實現許多不同的布局。網絡布局可以將應用程序分割成不同的空間,或者定義他們的大小、位置以及層級。
就像表格一樣,網格布局可以讓Web設計師根據元素按列或行對齊排列,但他和表格不同,網格布局沒有內容結構,從而使各種布局不可能與表格一樣。例如,一個網格布局中的子元素都可以定位自己的位置,這樣他們可以重疊和類似元素定位。
此外,沒有內容結構的網格布局有助于使用流體、調整順序等技術管理或更改布局。通過結合CSS的媒體查詢屬性,可以控制網格布局容器和他們的子元素,使用頁面的布局根據不同的設備和可用空間調整元素的顯示風格與定位,而不需要去改變文檔結構的本質內容。
瀏覽器兼容性眾觀下來,僅在IE10+上支持,而且也僅支持部分屬性。或許很多同學看到這樣的兼容性,又會止步,或者呵呵兩聲閃人了。不過我們學習是無防,在各瀏覽器中通過設置可以做測試效果,在下一次中將會向大家介紹如何在瀏覽器中開啟此功能。
Grid vs Flexbox在www-list郵件中常常會看到一種Pk的現像:談到網格就會扯到Flexbox。假設瀏覽器都支持這兩個模塊,你將選擇grid還是flexbox來給頁面布局。其實當你了解兩者之后你會很輕松的做出選擇。flexbox是一維布局,他只能在一條直線上放置你的內容區塊;而grid是一個二維布局。前面也簡單說到,你可以根據你的設計需求,將內容區塊放置到任何你想要放的地方。那么不用多說,你應該知道哪一種更適合你的布局。
網格術語想要玩轉CSS Grid Layout,就需要先了解網格給我們的一些新術語以及一些CSS屬性和值。在這一節中,將簡單的向大家解釋網格布局中的一些概念與術語。
網格線(Grid Lines)網格線組成了網格,他是網格的水平和垂直的分界線。一個網格線存在行或列的兩側。我們可以引用它的數目或者定義的網格線名稱。
上圖突出顯示的紅線就是第二列的網格線(line2)。
網格軌道(Grid Track)網格軌道是就是相鄰兩條網格線之間的空間,就好比表格中行或列。所在在網格中其分為grid column和grid row。每個網格軌道可以設置一個大小,用來控制寬度或高度。
圖中突出顯示的就是行線line2和line3之間組成的網格軌道。
網格單元格(Grid Cell)網格單元格是指四條網格線之間的空間。所以它是最小的單位,就像表格中的單元格。
圖中突出顯示的單元格是由行線line2、line3和列表line2、line3組成的。
網格區域(Grid Area)網格區域是由任意四條網格線組成的空間,所以他可能包含一個或多個單元格。相當于表格中的合并單元格之后的區域。
圖中突出顯示的網格區域是行線line1、line3和列線line2、line4之間的區域,其主要包括了四個網格單元格。
網格容器(Grid Containers)通過使用display屬性給元素顯式設置了屬性值grid或inline-grid,此時這個元素將自動變成網格容器。這個類似于flexbox一樣,將元素設置設置為display:flex,元素將自動變成彈性盒模型。
由于網格容器不是塊容器,所以有部分屬性在網格布局中將會失效:
多列布局模塊中的所有column-*屬性運用在網格容器上將失效
float和clear使用在網格項目(網格單元格Grid Cell)上將失效
vertical-align使用在網格單元格上將失效
::first-line和::first-letter這樣的偽元素不能應用在網格容器上
網格單元格順序(order)網格單元格順序和Flexbox模塊一樣,通過order屬性來對網格單父元格進行順序重排。
總結在這篇文章中簡單的介紹了CSS Grid Layout,以及為什么要使用他,并且介紹了其一些術語:網格線、網格軌道、網格單元格、網格區域和網格容器等,為后面如何學習和使用CSS Grid Layout做了一個鋪墊。希望這篇文章對于初學者有所幫助,如果您對此篇文章感興趣,請繼續觀注下一篇相關文章,將會向大家介紹如何在瀏覽器中開啟CSS Grid Layout模塊,讓你的測試用例能在瀏覽器中看到相關效果。
via w3cplus
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/110982.html
摘要:你可以用網格這樣做這樣的顯示效果是沒什么錯誤的,當使用網格,重新定義列數非常簡單。絕對定位當我們絕對定位一個網格元素的時候,這個元素會跑到它的容器中,我們可以用和來定位它。最簡單的命名約定使用網格自動編號。 注:此文是我翻譯的第一篇技術文章。適合有一定CSS原生網格布局使用經驗的開發者(讀前需要先去了解一下原生CSS網格的語法),原生CSS網格布局(Native CSS grid)截止...
摘要:你可以用網格這樣做這樣的顯示效果是沒什么錯誤的,當使用網格,重新定義列數非常簡單。絕對定位當我們絕對定位一個網格元素的時候,這個元素會跑到它的容器中,我們可以用和來定位它。最簡單的命名約定使用網格自動編號。 注:此文是我翻譯的第一篇技術文章。適合有一定CSS原生網格布局使用經驗的開發者(讀前需要先去了解一下原生CSS網格的語法),原生CSS網格布局(Native CSS grid)截止...
摘要:基于網格線的占位區網格中的單元格是有網格線劃分出來的,那么在網格布局中,同樣可以使用網格線來給子元素設置占位區域。也就是說這四條網格線間的區域是一個單元格。 CSS Grid布局對于我等來說就是一個全新的布局,但國外很多同行朋友已對這種布局做了全面的探知。前面花了兩篇內容(《CSS Grid布局:什么是網格布局》和《[CSS Grid布局:瀏覽器開啟CSS Grid Layout]ht...
摘要:簡單點說,就是由單元格慢慢過渡到具有合并單元格的布局在腦海中想想曾經愛過的。基于網格線使用關鍵詞實現單元格合并在布局中除了使用網格線合并單元格之外,還可以使用關鍵詞來實現單元格合并。 《CSS Grid布局:網格單元格布局》一文中通過一些簡單的實例介紹了如何給容器定義網格,并且怎么使用網格線或者網格區域來實現單元格這樣的簡單的布局。在文章結尾之處也提到過,這樣的單元格如同表格一樣,僅僅...
摘要:和絕對定位和絕對定位如果父容器有定位標識等,那么下面的子會根據原始它們應該布局的位置定位,反之如果父容器沒有定位標識,那么應用了會脫離布局,并且按照傳統的方式布局。基本概念 MDN上的解釋是這樣的 CSS Grid Layout excels at dividing a page into major regions or defining the relationship in term...
閱讀 2137·2023-04-25 18:49
閱讀 1840·2019-08-30 14:02
閱讀 2643·2019-08-29 17:24
閱讀 3323·2019-08-28 18:10
閱讀 2926·2019-08-28 18:03
閱讀 488·2019-08-26 12:01
閱讀 3309·2019-08-26 11:31
閱讀 1409·2019-08-26 10:29