色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          "); //-->

          博客專欄

          EEPW首頁 > 博客 > HTML5+CSS制作Grid網(wǎng)格布局入門及源碼分享

          HTML5+CSS制作Grid網(wǎng)格布局入門及源碼分享

          發(fā)布人:扣丁學(xué)習(xí) 時間:2020-11-11 來源:工程師 發(fā)布文章

          CSS Grid(網(wǎng)格) 布局使我們能夠比以往任何時候都可以更靈活構(gòu)建和控制自定義網(wǎng)格。 Grid(網(wǎng)格) 布局使我們能夠?qū)⒕W(wǎng)頁分成具有簡單屬性的行和列。它還能使我們在不改變?nèi)魏蜨TML的情況下,使用 CSS 來定位和調(diào)整網(wǎng)格內(nèi)的每個元素。它允許 HTML 純粹作為內(nèi)容的容器。HTML 結(jié)構(gòu)不再受限于樣式表現(xiàn),比如不要為了實現(xiàn)某種布局而多次嵌套,現(xiàn)在這些都可以讓 CSS 來完成。

          定義一個網(wǎng)格

          Grid(網(wǎng)格) 模塊為 display 屬性提供了一個新的值:grid。當(dāng)你將任何元素的 display 屬性設(shè)置為 grid 時,那么這個元素就是一個 網(wǎng)格容器(grid container),它的所有直接子元素就成了 網(wǎng)格項(grid items)。

          讓我們創(chuàng)建創(chuàng)建一個 3×3 的布局,做一個 Tic-Tac-Toe (井字游戲) 棋盤。 首先,我們將寫一些 HTML:

          HTML 代碼:

          如您所見,.game-board div 是網(wǎng)格容器,而 .box div 是網(wǎng)格項。現(xiàn)在我們將通過 Grid 布局來實現(xiàn) 3×3 布局。

          CSS 代碼:.game-board { display: grid; grid-template-rows: 200px 200px 200px; grid-template-columns: 200px 200px 200px;}

          在這里,我還使用了其他兩個屬性。 grid-template-rows 屬性允許我們指定網(wǎng)格中的行數(shù)及行的高度。那么你應(yīng)該猜到另一個屬性是干什么的了。

          grid-template-columns 屬性允許我們指定網(wǎng)格中的列數(shù)及列的寬度。您可以指定任何單位的尺寸大小,包括像素,百分比和其他單位fr,我們將在下一步學(xué)習(xí)。

          fr 單位(等分)

          fr 是為網(wǎng)格布局定義的一個新單位。它可以幫助你擺脫計算百分比,并將可用空間等分。

          例如,如果在網(wǎng)格容器中設(shè)置這個規(guī)則:grid-template-rows: 2fr 3fr,那么你的網(wǎng)格容器將首先被分成 2 行。然后將數(shù)字部分加在一起,這里總和為 5, 即 5 等分。

          就是說,我們將有 2 行:第一排占據(jù)垂直空間的 2/5 。 第二排占垂直空間的 3/5 。

          回到我們的 Tic-Tac-Toe 例子,我們使用 fr 代替 px。我們想要的是,應(yīng)該有3行3列。所以,我們只需要用 3 個 1fr 替換 3 個 200px 即可:

          CSS 代碼:.game-board { display: grid; grid-template-rows: 1fr 1fr 1fr; grid-template-columns: 1fr 1fr 1fr;}

          愚人碼頭注:

          這里特別需要注意的是: fr 單位是等分可用空間,或者說剩余空間??磦€例子

          CSS 代碼:.game-board { grid-gap:2px; display: grid; width:300px; height:200px; grid-template-rows: 100px 1fr 1fr; grid-template-columns: 1fr 50px 1fr;}

          布局效果如圖:

          你會看到 fr 單位是將 總的尺寸 減去 單元格明確尺寸后,在等分剩余空間。 grid-gap 是間隔。

          repeat() 函數(shù)

          在某些情況下,我們可能有很多的列和行。在 grid-template 屬性中指定每一個值可能會很乏味。幸運的是,有一個 repeat 函數(shù),就像任何一個循環(huán)重復(fù)多少次輸出某個給定值。它有兩個參數(shù)。第一個是迭代次數(shù),第二個是要重復(fù)的值。我們用 repeat 函數(shù)重寫上面的例子。

          CSS 代碼:.game-board{ display: grid; grid-template-rows: repeat(3, 1fr); grid-template-columns: repeat(3, 1fr);}

          等價于:

          CSS 代碼:.game-board { display: grid; grid-template-rows: 1fr 1fr 1fr; grid-template-columns: 1fr 1fr 1fr;}

          grid-template 屬性

          grid-template 屬性是 grid-template-rows 和 grid-template-columns 的簡寫語法。 這是它的語法:

          CSS 代碼:grid-template: ro ws / co lu mns;

          我們上面的例子使用這個簡寫語法后,看起來非常整齊。

          CSS 代碼:.game-board{ display: grid; grid-template: repeat(3, 1fr) / repeat(3, 1fr);}

          看,只需使用 2 行代碼,就可以使用網(wǎng)格布局創(chuàng)建 3×3 網(wǎng)格。

          我們在加一些背景和間隔后,上面的例子看起來像這樣:

          網(wǎng)格線編號,網(wǎng)格單元格,網(wǎng)格軌道

          網(wǎng)格線是存在于列和行每一側(cè)的線。一組垂直線將空間垂直劃分成列,而另一組水平線將空間水平劃分成行。這意味著在我們之前的例子中,有四條垂直線和四條水平線包含它們之間的行和列。

          在將網(wǎng)格項從一個位置跨越到另一個位置時,網(wǎng)格線變得非常有用。

          網(wǎng)格軌道是兩條線之間的空間。 網(wǎng)格軌道可以是一行或一列。

          網(wǎng)格單元格很像表格單元,是兩條相鄰垂直線和兩條相鄰水平線之間的空間。 這是網(wǎng)格中最小的單位。

          定位網(wǎng)格項

          我采取了前面的例子的網(wǎng)格,并用數(shù)字從1到9標(biāo)記每個單元格,而不是X或O,下面是它的樣子:

          假設(shè)我想將第 6 個框移到第 2 個框的位置。沒有CSS網(wǎng)格,不改變 HTML 的情況下,這幾乎是一個不可能的任務(wù),至少對我而言。(愚人碼頭注,如果單純這樣的效果圖,用FlexBox布局實現(xiàn)問題不大)但是如果我們使用網(wǎng)格模塊,改變網(wǎng)格中網(wǎng)格項的位置是一件輕而易舉的事情。要將第6個框移到第2個框的位置,我們必須確切知道第2個框在哪里。通過網(wǎng)格線編號的幫助,我們可以很容易地找到這個位置。第二個方框位于第2條列網(wǎng)格線之后,第3條列網(wǎng)格線之前,第1條行網(wǎng)格線之下,第2條行網(wǎng)格線之上?,F(xiàn)在我們可以使用以下屬性將這些網(wǎng)格線編號分配到第6個框中:

          grid-column-start

          grid-column-end

          grid-row-start

          grid-row-end

          前兩個屬性對應(yīng)于垂直網(wǎng)格線,也就是列網(wǎng)格線的開始和結(jié)束。 最后兩個屬性是指水平網(wǎng)格線,也就是行網(wǎng)格線的開始和結(jié)束。 讓我們分配正確的網(wǎng)格線編號來移動第 6 個框。

          CSS 代碼:.box:nth-child(6){ grid-row-start: 1; grid-row-end: 2; grid-column-start: 2; grid-column-end: 3;}

          還有兩個簡寫屬性用于將行和列的開始網(wǎng)格線和結(jié)束網(wǎng)格線設(shè)置在一起。

          CSS 代碼:.box:nth-child(6){ grid-row: 1 / 2; grid-column: 2 / 3;}

          此外,還有一個grid-area屬性是所有四個上述屬性的簡寫屬性。 它按以下順序取值:

          CSS 代碼:grid-area: / / / ;

          現(xiàn)在我們的例子可以寫成這樣

          CSS 代碼:.box:nth-child(6){ grid-area: 1 / 2 / 2 / 3;}

          上面的代碼行也可以進(jìn)一步減少。正如您所看到的,這個框只占用一行和一個列,所以我們只需要指定行和列的起始線,而無需結(jié)束線的值。

          CSS 代碼:.box:nth-child(6){ grid-area: 1 / 2;}

          如果我們想要第6個框跨越兩個框的區(qū)域呢? 這很容易通過將 column-end 值加 1 的辦法來完成。

          CSS 代碼:.box:nth-child(6){ grid-area: 1 / 2 / 2 / 4;}

          您也可以使用 span 關(guān)鍵字和占據(jù)的 軌道數(shù)量,來代替指定 grid-row-end 和 grid-column-end的結(jié)束網(wǎng)格線編號。 在這種情況下,第6個框是跨越 2 列和 1 行。

          CSS 代碼:.box:nth-child(6){ grid-area: 1 / 2 / 2 / span 2;}

          網(wǎng)格區(qū)域命名

          grid-area 屬性也可以用來命名網(wǎng)格的某一個部分,然后我們可以用 grid-template-areas屬性來定位。讓我們創(chuàng)建一個簡單的 bread-and-butter 布局,頂部有一個 top, nav,中間有 main 和 aside,下面是 footer。這是所需的HTML:

          HTML 代碼:

          我們需要使用 grid-area 屬性來命名每個區(qū)域:

          CSS 代碼:header{ grid-area: header; background-color: #9b59b6;} nav{ grid-area: nav; background-color: #3498db;} main{ grid-area: main; background-color: #2ecc71;} aside{ grid-area: aside; background-color: #f1c40f;} footer{ grid-area: footer; background-color: #1abc9c;}

          現(xiàn)在我們將使用 grid-template-areas 屬性來指定每個網(wǎng)格區(qū)域所占據(jù)的行和列。 以下是我們?nèi)绾巫龅降模?/p>

          CSS 代碼:.container{ display: grid; grid-template-rows: 1fr 5fr 1fr; grid-template-columns: 2fr 5fr 3fr; grid-template-areas: "header header header" "nav main aside" "footer footer footer"; grid-gap: .75em;}

          請注意,header 和 footer 單詞重復(fù)三次。 這表明,header 和 footer 橫跨 3 列的寬度。 你可以把它全部寫在一行中,但是把每一行寫在一個單獨的行上很好,很干凈。 你可以看到我在這里使用了一個新的屬性 grid-gap。 它所做的只是在兩個網(wǎng)格區(qū)域之間添加一個間距。 你也可以使用 grid-row-gap和 grid-column-gap 來為行和列指定不同的間距值。

          CodePen上的這個例子:

          瀏覽器支持

          在寫這篇文章的時候,CSS Grid 布局很多瀏覽器已經(jīng)原生支持。根據(jù) caniuse.com 的統(tǒng)計,所有主流瀏覽器都支持CSS Grid 布局,Internet Explorer 11 部分支持 -ms- 前綴, Opera Mini 根本不支持。

          結(jié)論

          CSS網(wǎng)格布局允許我們更快地布局,并且更容易控制。在本教程中,我們學(xué)習(xí)了如何用CSS網(wǎng)格來定義布局, fr單位,repeat 函數(shù)和一些網(wǎng)格系統(tǒng)中特定的術(shù)語。

          以上就是關(guān)于扣丁學(xué)堂HTML5培訓(xùn)之HTML5+CSS制作Grid網(wǎng)格布局入門及源碼的詳細(xì)介紹,最后想要工作不累就要不斷的提升自己的技能,請關(guān)注扣丁學(xué)堂官網(wǎng)、微信等平臺,扣丁學(xué)堂IT職業(yè)在線學(xué)習(xí)教育平臺為您提供權(quán)威的HTML5視頻教程系統(tǒng),通過千鋒扣丁學(xué)堂金牌講師在線錄制的第一套自適應(yīng)HTML5在線視頻課程系統(tǒng),讓你快速掌握HTML5從入門到精通開發(fā)實戰(zhàn)技能??鄱W(xué)堂H5技術(shù)交流群:751662650。

          *博客內(nèi)容為網(wǎng)友個人發(fā)布,僅代表博主個人觀點,如有侵權(quán)請聯(lián)系工作人員刪除。



          關(guān)鍵詞:

          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉