CSS Grid布局教程之什么是網(wǎng)格布局

CSS Grid現(xiàn)在已經(jīng)被W3C納入到CSS3的一個(gè)布局模塊當(dāng)中,被稱為CSS Grid Layout Module。而我們較為熟悉的還是將其想像成網(wǎng)格或者柵格,也就是早期的960gs。不管是網(wǎng)格還是柵格或者現(xiàn)在的CSS Grid Layout Module
,我想掌握這些技術(shù)對(duì)于我們將來在Web項(xiàng)目中實(shí)現(xiàn)布局只有好處沒有壞處。那么從今天開始我將和大家一起探討CSS中的網(wǎng)格布局。
在我們的Web內(nèi)容中,可以將其分割成很多個(gè)內(nèi)容塊,而這些內(nèi)容塊都占據(jù)自己的區(qū)域(regions
),可以將這些區(qū)域想像成是一個(gè)虛擬的網(wǎng)格。到目前為止,在一個(gè)模板中使用不同的結(jié)構(gòu)標(biāo)簽,使用多個(gè)浮動(dòng)和手動(dòng)計(jì)算實(shí)現(xiàn)一個(gè)布局。這對(duì)于Web前端人員來說,這是一件痛苦之事。而網(wǎng)格布局將讓你擺脫這樣的困局,讓你的布局方法變得非常簡單與清晰。
網(wǎng)格布局給了我們一種方法——創(chuàng)建的結(jié)構(gòu)與使用表格(table
)布局并沒有什么不同。然而,他是在CSS中實(shí)現(xiàn)而不是在HTML中實(shí)現(xiàn),同時(shí)還可以依賴于媒體查詢根據(jù)不同的上下文得新定義布局。這對(duì)于喜歡響應(yīng)式設(shè)計(jì)的同學(xué)來說是一個(gè)絕對(duì)利好的消息。因?yàn)槟悴辉谛枰贀?dān)心你的HTML結(jié)構(gòu)而影響你的布局。
網(wǎng)格布局還可以讓我們擺脫現(xiàn)在布局中存在的文檔流限制,換句話說,你的結(jié)構(gòu)不需要根據(jù)設(shè)計(jì)稿從上往上布置了。這也意味著您可以自由地更改頁面元素位置。這最適合你在不同的斷點(diǎn)位置實(shí)現(xiàn)你最需要的布局,而不再需要為響應(yīng)你的設(shè)計(jì)而擔(dān)心HTML結(jié)構(gòu)的問題。
什么是CSS Grid Layout?CSS Grid Layout是CSS為布局新增的一個(gè)模塊。網(wǎng)格布局特性主要是針對(duì)于Web應(yīng)用程序的開發(fā)者??梢杂眠@個(gè)模塊實(shí)現(xiàn)許多不同的布局。網(wǎng)絡(luò)布局可以將應(yīng)用程序分割成不同的空間,或者定義他們的大小、位置以及層級(jí)。
就像表格一樣,網(wǎng)格布局可以讓W(xué)eb設(shè)計(jì)師根據(jù)元素按列或行對(duì)齊排列,但他和表格不同,網(wǎng)格布局沒有內(nèi)容結(jié)構(gòu),從而使各種布局不可能與表格一樣。例如,一個(gè)網(wǎng)格布局中的子元素都可以定位自己的位置,這樣他們可以重疊和類似元素定位。
此外,沒有內(nèi)容結(jié)構(gòu)的網(wǎng)格布局有助于使用流體、調(diào)整順序等技術(shù)管理或更改布局。通過結(jié)合CSS的媒體查詢屬性,可以控制網(wǎng)格布局容器和他們的子元素,使用頁面的布局根據(jù)不同的設(shè)備和可用空間調(diào)整元素的顯示風(fēng)格與定位,而不需要去改變文檔結(jié)構(gòu)的本質(zhì)內(nèi)容。
瀏覽器兼容性眾觀下來,僅在IE10+
上支持,而且也僅支持部分屬性?;蛟S很多同學(xué)看到這樣的兼容性,又會(huì)止步,或者呵呵兩聲閃人了。不過我們學(xué)習(xí)是無防,在各瀏覽器中通過設(shè)置可以做測試效果,在下一次中將會(huì)向大家介紹如何在瀏覽器中開啟此功能。
Grid
vs Flexbox
在www-list
郵件中常常會(huì)看到一種Pk的現(xiàn)像:談到網(wǎng)格就會(huì)扯到Flexbox。假設(shè)瀏覽器都支持這兩個(gè)模塊,你將選擇grid
還是flexbox
來給頁面布局。其實(shí)當(dāng)你了解兩者之后你會(huì)很輕松的做出選擇。flexbox
是一維布局,他只能在一條直線上放置你的內(nèi)容區(qū)塊;而grid
是一個(gè)二維布局。前面也簡單說到,你可以根據(jù)你的設(shè)計(jì)需求,將內(nèi)容區(qū)塊放置到任何你想要放的地方。那么不用多說,你應(yīng)該知道哪一種更適合你的布局。
想要玩轉(zhuǎn)CSS Grid Layout,就需要先了解網(wǎng)格給我們的一些新術(shù)語以及一些CSS屬性和值。在這一節(jié)中,將簡單的向大家解釋網(wǎng)格布局中的一些概念與術(shù)語。
網(wǎng)格線(Grid Lines)網(wǎng)格線組成了網(wǎng)格,他是網(wǎng)格的水平和垂直的分界線。一個(gè)網(wǎng)格線存在行或列的兩側(cè)。我們可以引用它的數(shù)目或者定義的網(wǎng)格線名稱。
上圖突出顯示的紅線就是第二列的網(wǎng)格線(line2
)。
網(wǎng)格軌道是就是相鄰兩條網(wǎng)格線之間的空間,就好比表格中行或列。所在在網(wǎng)格中其分為grid column
和grid row
。每個(gè)網(wǎng)格軌道可以設(shè)置一個(gè)大小,用來控制寬度或高度。
圖中突出顯示的就是行線line2
和line3
之間組成的網(wǎng)格軌道。
網(wǎng)格單元格是指四條網(wǎng)格線之間的空間。所以它是最小的單位,就像表格中的單元格。
圖中突出顯示的單元格是由行線line2
、line3
和列表line2
、line3
組成的。
網(wǎng)格區(qū)域是由任意四條網(wǎng)格線組成的空間,所以他可能包含一個(gè)或多個(gè)單元格。相當(dāng)于表格中的合并單元格之后的區(qū)域。
圖中突出顯示的網(wǎng)格區(qū)域是行線line1
、line3
和列線line2
、line4
之間的區(qū)域,其主要包括了四個(gè)網(wǎng)格單元格。
通過使用display
屬性給元素顯式設(shè)置了屬性值grid
或inline-grid
,此時(shí)這個(gè)元素將自動(dòng)變成網(wǎng)格容器。這個(gè)類似于flexbox
一樣,將元素設(shè)置設(shè)置為display:flex
,元素將自動(dòng)變成彈性盒模型。
由于網(wǎng)格容器不是塊容器,所以有部分屬性在網(wǎng)格布局中將會(huì)失效:
多列布局模塊中的所有column-*
屬性運(yùn)用在網(wǎng)格容器上將失效float
和clear
使用在網(wǎng)格項(xiàng)目(網(wǎng)格單元格Grid Cell)上將失效vertical-align
使用在網(wǎng)格單元格上將失效::first-line
和::first-letter
這樣的偽元素不能應(yīng)用在網(wǎng)格容器上網(wǎng)格單元格順序(order)
網(wǎng)格單元格順序和Flexbox模塊一樣,通過order
屬性來對(duì)網(wǎng)格單父元格進(jìn)行順序重排。
在這篇文章中簡單的介紹了CSS Grid Layout,以及為什么要使用他,并且介紹了其一些術(shù)語:網(wǎng)格線、網(wǎng)格軌道、網(wǎng)格單元格、網(wǎng)格區(qū)域和網(wǎng)格容器等,為后面如何學(xué)習(xí)和使用CSS Grid Layout做了一個(gè)鋪墊。希望這篇文章對(duì)于初學(xué)者有所幫助,如果您對(duì)此篇文章感興趣,請(qǐng)繼續(xù)觀注下一篇相關(guān)文章,將會(huì)向大家介紹如何在瀏覽器中開啟CSS Grid Layout模塊,讓你的測試用例能在瀏覽器中看到相關(guān)效果。
相關(guān)文章
CSS3中的display:grid,網(wǎng)格布局介紹
這篇文章主要介紹了CSS3中的display:grid,網(wǎng)格布局介紹,需要的朋友可以參考下2019-10-30js和CSS3實(shí)現(xiàn)帶詳情頁面的炫酷網(wǎng)格布局特效
這是一款js和CSS3實(shí)現(xiàn)帶詳情頁的炫酷網(wǎng)格布局的特效,當(dāng)鼠標(biāo)移動(dòng)到某一項(xiàng)上時(shí),會(huì)有文字動(dòng)畫的效果。當(dāng)點(diǎn)擊了某一項(xiàng)后,會(huì)進(jìn)入相應(yīng)的詳情頁面2018-09-27- 這篇文章主要介紹了CSS Grid 網(wǎng)格布局全解析的相關(guān)資料,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-29
- 這篇文章主要介紹了CSS網(wǎng)格布局的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-11-29
在CSS網(wǎng)格布局中的列中填充項(xiàng)目的實(shí)現(xiàn)方法
這篇文章主要介紹了在CSS網(wǎng)格布局中的列中填充項(xiàng)目的實(shí)現(xiàn)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-14