摘要:瀏覽器兼容性網(wǎng)格布局從開始收到支持,微軟在會更新對網(wǎng)格布局的支持。微軟的瀏覽器和有一種比較舊的實現(xiàn),所以有不少限制,我們會簡單介紹新的實現(xiàn)方式和老的實現(xiàn)方式之間的區(qū)別,這樣你能知道如何規(guī)避他們。
原文地址:Getting to know CSS Grid Layout
原文作者:Chris Wright
譯者:華翔
校對者:珂珂、干干
翻譯 | CSS網(wǎng)格(CSS Grid)布局入門CSS網(wǎng)格布局是瀏覽器Flexbox布局之后最重要的布局方式。我們可以忘記過去15年經(jīng)常使用的的各種“神奇數(shù)字”,hacks和一系列變通布局方案。網(wǎng)格布局提供了非常簡單的聲明布局方式,之后再也不需要借助一些常見的主流css框架,也能減少很多手動實現(xiàn)的布局方式
如果你以前不熟悉CSS網(wǎng)格布局,那么你可以開始了解它了。它是一種適用于容器元素,并能指定子元素的間距、大小和對齊方式的布局工具。
CSS網(wǎng)格布局賦予我們更強大的能力——大家熟悉的水平垂直居中布局,不需要增加標簽就能做到。同樣,這也能讓我們不需要媒體查詢就能根據(jù)可用空間自動適應。
學習的最低要求首先網(wǎng)格布局有不少新語法需要學習,但是你只需要稍微看下就能上手。本文將會用示例帶你學習CSS網(wǎng)格布局各種各樣重要的入門概念。
瀏覽器兼容性CSS網(wǎng)格布局從Safari 10.1, Firefox 52, Opera 44, Chrome 57開始收到支持,微軟Edge在Edge 15會更新對網(wǎng)格布局的支持。
微軟的瀏覽器(IE10–11和Edge 13-14)有一種比較舊的實現(xiàn),所以有不少限制,我們會簡單介紹新的實現(xiàn)方式和老的實現(xiàn)方式之間的區(qū)別,這樣你能知道如何規(guī)避他們。
對于大多數(shù)布局,我們會使用下面的query特性來讓老的瀏覽器對他們理解的特性也能工作:
@supports (display: grid) { .grid { display: grid; } }
不支持瀏覽器@supports或網(wǎng)格的瀏覽器將不會生效。
為了能正確展示文中的示例,你需要使用支持網(wǎng)格布局的瀏覽器。
創(chuàng)建帶有間距(gutter)的兩列(column)網(wǎng)格為了演示CSS網(wǎng)格布局如何定義列,我們從下面的布局開始:
[使用grid-template-columns 和 grid-gap創(chuàng)建帶間距的兩列布局]
為了創(chuàng)建上述網(wǎng)格布局,我們需要使用grid-template-columns和grid-gap。
grid-template-columns表示網(wǎng)格中的列是如何布局的,它的值是一連串以空格分割的的值,這些值標識每列的大小,值的個數(shù)表示列的數(shù)目。
例如,四列250px寬度的網(wǎng)格布局可以這樣表示:
grid-template-columns: 250px 250px 250px 250px;
也可以使用repeat關鍵字表示:
grid-template-columns: repeat(4, 250px);定義間距
grid-gap定義了網(wǎng)格布局的間距大小,接收一個或兩個值,如果定義兩個值則表示列(column)和行(row)的間距大小。
在兩列布局示例中,我們可以如下使用:
.grid { display: grid; grid-template-columns: 50vw 50vw; grid-gap: 1rem; }
不幸的是,這個間距將會占用容器元素的整體寬度,計算出來就是100vw + 1rem,最終這個布局會導致出現(xiàn)水平滾動條。
[通過viewport單位創(chuàng)建帶間距網(wǎng)格導致的水平滾動條]
為了解決這個空間溢出問題,我們需要些不同的方法來處理,需要用分數(shù)單位或者說是FR。
分數(shù)單位分數(shù)單位標識占用可用空間的份額,如果900px是可用空間,其中的一個元素占有1份,另外的元素占有2份——那么第一個元素的寬度會是900px的1/3,另外的元素是900px的2/3。
修改后用分數(shù)代替view-port單位的新代碼如下:
.grid { display: grid; grid-template-columns: 1fr 1fr; grid-gap: 1rem; }內容對齊
為了對齊示例中的內容,我們在子元素上使用grid布局,并加上對齊屬性來定位他們到指定軌道(track),軌道就是一個網(wǎng)格的列或行的某個位置的常見的名稱。網(wǎng)格跟Flex布局一樣,有一系列對齊的屬性——共有四種值——start, center, end, 和stretch,分別對應其子元素所在的軌道。stretch跟其他不太一樣,它會將元素從所在軌道的頭拉伸到尾。
[align-items 和 justify-content]
例子中我們要將內容水平和垂直居中,可以通過在容器上設置下面這些屬性:
.center-content { display: grid; align-items: center; justify-content: center; }
示例地址
使用舊的網(wǎng)格布局實現(xiàn)兩欄布局如果使用舊的網(wǎng)格布局方式創(chuàng)建,我們需要考慮實現(xiàn)中的諸多限制。舊的布局方式不僅沒有grid-gap,而且你需要在每一個網(wǎng)格元素上聲明網(wǎng)格元素的起始位置,否則默認會設置為1,這樣所有的網(wǎng)格都會堆在第一列。
舊版本的布局方式需要通過增加間距作為網(wǎng)格軌道的一部分,也需要設置每個網(wǎng)格從哪里開始:
.grid-legacy { display: -ms-grid; -ms-grid-columns: 1fr 1rem 1fr; // 取代 gap 間距 } .grid-legacy:first-child { -ms-grid-column: 1; } .grid-legacy:last-child { -ms-grid-column: 3; }舊的布局方式實現(xiàn)對齊和全高度
舊的布局方式跟IE 11中Flexbox有一樣的問題,在容器上設置最小高度(min-height)不一定會生效。這個問題通過網(wǎng)格布局來解決更方便。
為了實現(xiàn)這個效果我們在父容器的行屬性上使用minmax方法,minmax指定了行或列的最大和最小值。
-ms-grid-rows: minmax(100vh, 1fr);
在子元素上我們聲明一個單位為1fr的單列單行的網(wǎng)格:
.ms-cell { -ms-grid-columns: 1fr; -ms-grid-rows: 1fr; }
最后,因為我們不能像Flexbox或最新網(wǎng)格布局那樣根據(jù)父元素對齊,我們必須使用元素自身的對齊方式來對齊:
.ms-align-center { -ms-grid-column: 1; -ms-grid-column-align: center; // 新型grid布局中的 align-self -ms-grid-row-align: center; // 新型grid布局中的 justify-self }
舊的兩列布局示例
到此我們實現(xiàn)了如何創(chuàng)建列、實現(xiàn)間距、內容對齊及對舊的網(wǎng)格布局的支持。接下來讓我們實驗下如何通過grid實現(xiàn)內邊距。
通過CSS網(wǎng)格實現(xiàn)內邊距(Negative Space)網(wǎng)格布局允許你通過grid-column-start屬性指定列開始的位置,所以就有了可以在網(wǎng)格內創(chuàng)建內邊距的可能性。
[使用grid-template-columns和grid-column-start創(chuàng)建內邊距]
創(chuàng)建內邊距的一種方式是在列的實際位置上設置一個數(shù)字,空出網(wǎng)格元素的原始空間, 網(wǎng)格元素也會被push到新的網(wǎng)格列。
[隨著grid-column-start push 第一項]
在上面的內邊距示例中,html結構中用一個div包裹另外一個div:
網(wǎng)格像這樣設置:
.grid { display: grid; grid-template-columns: 1fr 1fr; }為了讓子元素從右側開始,我們設置子元素從第2列開始:
.child { grid-column-start: 2; }注意:在Firefox 52中的一個差異導致一個垂直對齊問題——基于FR單位的行不會拉伸得跟整個窗口一樣高。為了解決(address)這個問題我們設置子元素為網(wǎng)格項,并給每一行設置一個想要的高度:
.l-grid--full-height { grid-template-rows: minmax(100vh, 1fr); }設置內邊距示例
用內容死區(qū)(content dead-zones)創(chuàng)建空白在四列布局中,給本來在第三列的網(wǎng)格項上設置grid-column-start:2;,那么會找到下一個可用的第二列來填充空間。
網(wǎng)格軌道會跳過某些列,直到找到下一列。我們可以利用這個方法在網(wǎng)格內創(chuàng)建空白,沒有內容的網(wǎng)格也會被分配。
[創(chuàng)建空白示例]創(chuàng)建行
[使用grid-template-columns 和 grid-column-start創(chuàng)建空白]如果我們想分割布局為四份,我們目前所了解的關于列的布局方式對行同樣有效:
.grid { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 250px 250px; }
[同時使用grid-template-columns 和 grid-template-rows創(chuàng)建網(wǎng)格布局]理想情況下這個示例是沒問題的。因為此時每個網(wǎng)格項的內容足夠少而不會撐開每行。但隨著內容的變化,一切都不一樣了。當示例中的內容超出指定行的大小后,看下會發(fā)生什么:
[內容超出聲明的行高]我們創(chuàng)建了250px高的兩行,如果內容超過每行的高度,將會打破布局并和后面的行的內容重疊。并不是一個我們想要的結果。
靈活的設置最小值我們在該場景下需要的是設置最小尺寸的能力,但又要允許尺寸可以根據(jù)內容彈性變化。這里我們通過上面舊瀏覽器示例中的minmax關鍵字實現(xiàn)。
.grid { grid-template-rows: minmax(250px, auto) minmax(250px, auto); }創(chuàng)建有最小值的彈性行
現(xiàn)在我們已經(jīng)了解了創(chuàng)建帶有內容的行的基礎方法,我們開始來創(chuàng)建水平和垂直交錯的更復雜網(wǎng)格布局。
創(chuàng)建更復雜的網(wǎng)格
[使用grid-column-start和span關鍵字創(chuàng)建復雜網(wǎng)格布局Unsplash]我們開始創(chuàng)建更復雜的網(wǎng)格布局。將網(wǎng)格中的每個網(wǎng)格項設置成占據(jù)多條軌道,在一列內,我們能通過grid-column-start和grid-column-end實現(xiàn),或者通過如下所示更簡單的寫法:
grid-column: 1 / 3;用這種實現(xiàn)方式的弊端是難以“模塊化”,為了定位每塊內容需要寫很多代碼。span關鍵字更符合模塊化的思路,因為我們能放在任何地方,讓網(wǎng)格來控制他。我們可以定義網(wǎng)格項的開始位置,及其占據(jù)的軌道數(shù):
.span-column-3 { grid-column-start: span 3; }任何添加該class的網(wǎng)格將會從其開始位置,占據(jù)三個軌道。
[通過span實現(xiàn)的復雜網(wǎng)格]
使用span設計一個布局我們能設計一個多軌道布局,通過將布局分解為grid布局中的最小單元。本示例中的最小單位是圖中高亮的部分。
[通過最小網(wǎng)格單位結合span創(chuàng)建更大的網(wǎng)格]圍繞最小單位,我們能靈活的使用span來創(chuàng)建一些有意思的布局,因為span是可以疊加的——你可以結合列和行的軌道在網(wǎng)格中創(chuàng)建多層級。
不需要媒體查詢(media queries)的彈性網(wǎng)格雖然上面說到的例子能在可用空間內適應變化,但是沒有一個是專門為空間變化設計的。網(wǎng)格有兩個非常有用的特性來適應可用空間的變化。這兩個屬性叫‘a(chǎn)uto-fit’和‘a(chǎn)uto-fill’,像下面這樣結合repeat function和minmax function使用:
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));這些值代替了repeat中的數(shù)字,并計算在每條軌道上會填充多少行或列。二者之間最大不同是當一條軌道上空白的溢出時的他們的處理方式不同。
auto-fit嘗試在不導致列溢出的情況下,放置該列能處理的最大數(shù)量的重復元素。當沒有足夠的空間來放置更多的元素時,之后的元素將會放到下一行,不能填滿的空間將會被保留。
[示例:auto-fill. auto-fill會保留后面空間,反之a(chǎn)uto-fit會讓空白收縮為0px]auto-fill的表現(xiàn)跟auto-fit類似,但是任何的空白空間都會自動收縮,同時這一行的元素也會被拉升——類似flexbox的效果,列會隨著可用空間變小發(fā)生折疊。
[grid-auto-fit示例]
依賴媒體查詢的布局跟窗口大小關系很大,這不夠模塊化——系統(tǒng)內的組件應該能根據(jù)可用空間自適應。那么在實踐中會是什么樣的呢?
[grid auto-fit的真實示例][網(wǎng)格auto-fit示例]
這只是冰山一角我們已經(jīng)經(jīng)歷了快十五年的CSS浮動為主的布局方式,我們上面學習了幾乎所有你能用float實現(xiàn)的布局——CSS網(wǎng)格布局是這個領域的新代表,仍然還有許多東西需要去嘗試和學習。
現(xiàn)在最重要的步驟是開始使用它。在構建、創(chuàng)建更多高級布局的時候會很方便。網(wǎng)格布局還有不少未知領域,一旦我們更好地理解其能力并開始與其他特性結合,我們便能用更少代碼創(chuàng)造更多有趣、靈活的布局,并能減少些框架抽象的麻煩。
如果你感興趣并想進一步探究CSS網(wǎng)格,可以試下Rachel Andrew的例子,這里面通過帶解釋說明的實例探討了CSS網(wǎng)格布局的每一個特性。
iKcamp原創(chuàng)新書《移動Web前端高效開發(fā)實戰(zhàn)》已在亞馬遜、京東、當當開售。
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/112507.html
摘要:簡介網(wǎng)格布局又稱網(wǎng)格,是一種二維網(wǎng)格布局系統(tǒng)。在處理網(wǎng)頁布局方面一直做的不是很好。網(wǎng)格容器中的所有子元素就會自動變成網(wǎng)格項目網(wǎng)格線組成網(wǎng)格線的分界線。 簡介 CSS網(wǎng)格布局(又稱網(wǎng)格),是一種二維網(wǎng)格布局系統(tǒng)。CSS在處理網(wǎng)頁布局方面一直做的不是很好。一開始我們用的是table(表格)布局,然后用float(浮動),position(定位)和inline-block(行內塊)布局,但是...
摘要:接下來我們用設置父類元素在這我放一下完整的和代碼則顯示結果如下現(xiàn)在你可能看到似乎沒什么變化。只需要這樣寫確保在你能用電腦在新窗口打開下面這個鏈接,來試試改變?yōu)g覽器窗口大小,看看響應式效果。黃色表示部分支持。 showImg(https://segmentfault.com/img/remote/1460000010000550); 前言 三月中旬的時候,有一個對于 CSS 開發(fā)者來說很...
摘要:接下來我們用設置父類元素在這我放一下完整的和代碼則顯示結果如下現(xiàn)在你可能看到似乎沒什么變化。只需要這樣寫確保在你能用電腦在新窗口打開下面這個鏈接,來試試改變?yōu)g覽器窗口大小,看看響應式效果。黃色表示部分支持。 showImg(https://segmentfault.com/img/remote/1460000010000550); 前言 三月中旬的時候,有一個對于 CSS 開發(fā)者來說很...
摘要:一切都那么美好,除了讓人惡心的初代布局。第二個,豆腐塊布局。那么就開始看看第四代網(wǎng)絡布局神奇布局的強大之處。 showImg(https://segmentfault.com/img/bVbenWU?w=500&h=500); 一轉眼已經(jīng)2018年,前端行業(yè)也風風雨雨的走過了10多年,網(wǎng)頁布局也從最原始的文檔變成成了當前精彩紛呈的交互。當我看到第四代css布局技術網(wǎng)格布局的時候,就像我...
摘要:一切都那么美好,除了讓人惡心的初代布局。第二個,豆腐塊布局。那么就開始看看第四代網(wǎng)絡布局神奇布局的強大之處。 showImg(https://segmentfault.com/img/bVbenWU?w=500&h=500); 一轉眼已經(jīng)2018年,前端行業(yè)也風風雨雨的走過了10多年,網(wǎng)頁布局也從最原始的文檔變成成了當前精彩紛呈的交互。當我看到第四代css布局技術網(wǎng)格布局的時候,就像我...
閱讀 3175·2021-11-23 09:51
閱讀 688·2021-10-14 09:43
閱讀 3211·2021-09-06 15:00
閱讀 2410·2019-08-30 15:54
閱讀 2565·2019-08-30 13:58
閱讀 1853·2019-08-29 13:18
閱讀 1384·2019-08-27 10:58
閱讀 517·2019-08-27 10:53