亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

css中grid布局的案例分析

發布時間:2020-12-08 13:50:06 來源:億速云 閱讀:429 作者:小新 欄目:web開發

小編給大家分享一下css中grid布局的案例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

CSS網格布局(又稱“網格”),是一種二維網格布局系統。CSS在處理網頁布局方面一直做的不是很好。一開始我們用的是table(表格)布局,然后用float(浮動),position(定位)和inline-block(行內塊)布局,但是這些方法本質上是hack,遺漏了很多功能,例如垂直居中。后來出了flexbox盒布局,解決了很多布局問題,但是它僅僅是一維布局,而不是復雜的二維布局,實際上它們(flexbox與grid)能很好的配合使用。

瀏覽器支持情況

在我們開始正式學習Grid布局之前,先看一下can i use上grid布局在各個瀏覽器下的支持情況是很有用的,

css中grid布局的案例分析

基本概念

要想學好Grid布局的用法,基本概念的介紹是少不了的,雖然看起來比較枯燥。

網格容器(Grid Container)

通過display屬性設置屬性值為grid或inline-grid可以創建一個網格容器。網格容器中的所有子元素就會自動變成網格項目(Grid item)

網格線(Grid Line)

組成網格線的分界線。它們可以是列網格線(column grid lines),也可以是行網格線(row grid lines)并且居于行或列的任意一側

網格軌道(Grid Track)

兩個相鄰的網格線之間為網格軌道。你可以認為它們是網格的列或行

網格單元(Grid Cell)

兩個相鄰的列網格線和兩個相鄰的行網格線組成的是網格單元,它是最小的網格單元

網格區(Grid  Area)

網格區是由任意數量網格單元組成

基本屬性及作用

一個簡單例子

要介紹Grid布局屬性,讓我們先從一個簡單例子開始:

css中grid布局的案例分析

如上圖所示,如果我們要實現一個3x3的正方形矩陣,用Grid布局要怎么實現?

 <div class="container">
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
</div>
.container {
    display: grid;
    width: 200px;
    height: 200px;
    grid-template-rows: repeat(3, 50px);
    grid-template-columns: repeat(3, 50px);
    grid-row-gap: 10px;
    grid-column-gap:10px;
}
.container p {
    background-color: #ccc;
    border: 1px solid #333;
}

如上面代碼所示,3x3的矩陣布局,用Grid布局去寫,非常簡單方便,相對于使用其他布局來說,Grid布局的優點就顯現出來了,那么,接下來就讓我們看看Grid局部中那些常用屬性:

grid-template-rows:指定的每個值可以創建每行的高度。行高的尺寸可以是任何非負值,長度可以是px、%、em等長度單位的值

grid-template-columns:指定的每個值來創建每列的列寬

repeat函數:使用repeat()可以創建重復的網格軌道。這個適用于創建相等尺寸的網格項目和多個網格項目,repeat()接受兩個參數:第一個參數定義網格軌道應該重復的次數,第二個參數定義每個軌道的尺寸

grid-column-gap和grid-row-gap屬性用來創建列與列,行與行之間的間距,間距(Gap)可以設置任何非負值,長度值可以是px、%、em等單位值。

網格線號碼定位

依舊是上面html代碼,一個3x3的矩陣,不同的是這次我們通過網線號碼來定位某一個特定方塊。

.container {
    display: grid;
    width: 200px;
    height: 200px;
    grid-template-rows: repeat(3, 50px);
    grid-template-columns: repeat(3, 50px);
}
.container div {
    background-color: #ccc;
    border: 1px solid #333;
    grid-column-start: 2;
    grid-column-end: 3;
    grid-row-start: 2;
    grid-row-end: 3; 
/*  grid-area: 2/2/3/3; */
  }

通過上面的代碼我們可以實現如下效果:

css中grid布局的案例分析

我們定位矩陣正中間的小方塊顯示出來,其余的就不顯示了,下面我們網格線號碼定位的那些屬性:

每條線是從網格軌道開始,網格的網格線從1開始,每條網格線逐步增加1

grid-row-start:表示開始的行網格線序號

grid-row-end:表示結束的行網格線序號

grid-column-start:表示開始的列網格線序號

grid-row-end:表示結束的列網格線序號

如果一個網格項目跨度只有一行或一列,那么grid-row-end和grid-column-end不是必需的

grid-area:網格區域,也是用來定位,如果只提供一個值,它指定了grid-row-start和grid-column-start的值。如果提供兩個值,第一個值是grid-row-start、grid-column-start的值,第二個值是grid-row-end、grid-column-end的值,兩者之間必須要用/隔開。如果指定四個值,第一個值對應grid-row-start,第二個值對應grid-column-start,第三個值對應grid-row-end和第四個值對應grid-column-end

網格區域命名定位網格項目

通過上面的例子,我們知道了如何用網格線去定位網格項目,接下來我們將學習如何通過網格區域的命名來定位網格項目,老樣子,依舊從一個例子開始:

<div class="container">
    <div class="first"></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
    <div></div>
</div>
.container {
    display: grid;
    width: 400px;
    height: 400px;
    grid-template-rows: repeat(3, 100px);
    grid-template-columns: repeat(3, 100px);
    grid-template-areas: "header header2 header3" "body body2 body3" "footer footer2 footer3";
}
.container div {
    background-color: #ccc;
    border: 1px solid #333;
}
.container .first {
    grid-row-start: header2;
    grid-row-end: body2;
    grid-column-start: header;
    grid-column-end: header2;
}

css中grid布局的案例分析

如上述例子看到的,本來是一個3x3的矩陣,但是通過區域命名的方式,將第一個p設置了跨兩行兩列,接下來讓我們一起了解一下網格區域命名定位網格項目的相關屬性:

  • 像網格線名稱一樣,網格區域的名稱也可以使用grid-template-areas屬性來命名。引用網格區域名稱也可以設置網格項目位置

  • 設置網格區域的名稱應該放置在單引號或雙引號內,每個名稱由一個空格符分開。網格區域的名稱,每組(單引號或雙引號內的網格區域名稱)定義了網格的一行,每個網格區域名稱定義網格的一列

  • grid-row-start和grid-row-end通過區域命名分別設置了行開始的位置和結束,grid-column-start和grid-column-end通過區域命名分別設置了列開始的位置和結束位置

總結

這篇文章簡單的介紹了一些Grid布局的屬性和用法,但沒有涉及所有,Grid布局還有很多屬性和用法需要自己去探索,通過不同屬性的排列組合,可以發掘不同的玩法,這不正是布局的魅力嗎?

以上是“css中grid布局的案例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

三台县| 开平市| 新丰县| 平南县| 阳新县| 旌德县| 大田县| 松阳县| 丰原市| 房产| 贵港市| 珠海市| 岳西县| 门源| 满城县| 吐鲁番市| 东平县| 体育| 井陉县| 驻马店市| 平果县| 谢通门县| 京山县| 吉首市| 蓝田县| 乌苏市| 榆社县| 仙游县| 张家口市| 全椒县| 靖安县| 金湖县| 长岭县| 阳春市| 宁安市| 北辰区| 峨眉山市| 晋宁县| 望江县| 洛扎县| 周口市|