摘要:效果如圖響應式布局例子實現(xiàn)如圖效果結構布局使用屬性創(chuàng)建一個列的網(wǎng)格,每個列都是一個單位寬度總寬度的。嘗試其它布局把移到右邊實現(xiàn)后的效果使用點來創(chuàng)建空白的網(wǎng)格單元格實現(xiàn)效果真正的響應式布局假設你想在移動設備上查看的是標題旁邊是菜單。
為了使其成為二維的網(wǎng)格容器,我們需要定義列和行。讓我們創(chuàng)建3列和2行。我們將使用grid-template-row
和grid-template-column
屬性。
.wrapper {
display: grid;
grid-template-columns: 100px 100px 100px;
grid-template-rows: 50px 50px;
}
grid-template-columns
的3個值表示三列,相應的數(shù)值表示列寬
即都為100px。grid-template-rows
的2個值表示兩行,相應的數(shù)值表示行高
即都為50px
可以變化一下行高跟列寬的值看下效果,代碼:
.wrapper {
display: grid;
grid-template-columns: 200px 50px 100px;
grid-template-rows: 100px 30px;
}
我們使用與之前相同的 HTML 標記,為了幫助我們更好的理解,我們在每個 items(子元素) 加上了多帶帶的 class :
class="wrapper">
class="item1">1
class="item2">2
class="item3">3
class="item4">4
class="item5">5
class="item6">6
創(chuàng)建一個 3×3 的 grid(網(wǎng)格):
.wrapper {
display: grid;
grid-template-columns: 100px 100px 100px;
grid-template-rows: 100px 100px 100px;
}
在頁面上看到 3×2 的 grid(網(wǎng)格),而我們定義的是 3×3 的 grid(網(wǎng)格)。這是因為我們只有 6 個 items(子元素) 來填滿這個網(wǎng)格。如果我們再加3個 items(子元素),那么最后一行也會被填滿。
定位和調(diào)整(item)子元素大小
要定位和調(diào)整 items(子元素) 大小,我們將使用?grid-column
?和?grid-row
?屬性來設置:
.item1 {
grid-column-start: 1;
grid-column-end: 4;
}
當然可以有簡寫方式:
.item1 {
grid-column: 1 / 4;
}
上面代碼意思就是: item1 占據(jù)從第一條網(wǎng)格線開始,到第四條網(wǎng)格線結束。顯示效果如下:
如果你不明白我們設置的只有 3 列,為什么有4條網(wǎng)格線呢?看看下面這個圖像,黑色的列網(wǎng)格線你就明白了:
如果上面的看懂了,來個復雜點的鞏固下。
.item1 {
grid-column-start: 1;
grid-column-end: 3;
}
.item3 {
grid-row-start: 2;
grid-row-end: 4;
}
.item4 {
grid-column-start: 2;
grid-column-end: 4;
}
效果如圖:
實現(xiàn)如圖效果:
<style>
.container {
display: grid;
grid-template-columns: repeat(12, 1fr);
grid-template-rows: 50px 350px 50px;
grid-gap: 5px;
}
style>
<div class="container">
<div class="header">HEADERdiv>
<div class="menu">MENUdiv>
<div class="content">CONTENTdiv>
<div class="footer">FOOTERdiv>
div>
使用?grid-template-columns
?屬性創(chuàng)建一個 12 列的網(wǎng)格,每個列都是一個單位寬度(總寬度的 1/12 )。(愚人碼頭注:其中,?repeat(12, 1fr)
?意思是 12 個重復的 1fr 值。?fr
?是網(wǎng)格容器剩余空間的等分單位。)
使用?grid-template-rows
?屬性創(chuàng)建 3 行,第一行高度是 50px ,第二行高度是 350px 和第三行高度是 50px。
使用?grid-gap
?屬性在網(wǎng)格中的網(wǎng)格項之間添加一個間隙
。
這個屬性被稱為網(wǎng)格區(qū)域
,也叫模板區(qū)域
,能夠讓我們輕松地進行布局實驗。
要將它添加到網(wǎng)格中,我們只需給網(wǎng)格容器加一個?grid-template-areas?
屬性即可。 語法可能有點奇怪,因為它不像其他的 CSS 語法。例如:
.container {
display: grid;
grid-gap: 5px;
grid-template-columns: repeat(12, 1fr);
grid-template-rows: 50px 350px 50px;
grid-template-areas:
"h h h h h h h h h h h h"
"m m c c c c c c c c c c"
"f f f f f f f f f f f f";
}
上面代碼創(chuàng)建3行12列,上面grid-template-areas
屬性中的值,每行代表一行,用網(wǎng)格術語來說是 網(wǎng)格軌道(Grid Track) ,每個字符(?h,m,c,f
)代表一個網(wǎng)格單元格。愚人碼頭注:其實是 網(wǎng)格區(qū)域(Grid Area) 名稱,你可以使用任意名稱
。
你可能已經(jīng)猜到,我選擇了字符 h,m,c,f,是因為他們是 header, menu, content 和 footer 的首字母。 當然,我可以把它們叫做任何想要的名稱,但是使用他們所描述的東西的第一個字符更加容易讓人理解。
現(xiàn)在我們需要將這些字符與網(wǎng)格中的網(wǎng)格項建立對應的連接。 要做到這一點,我們將在網(wǎng)格項使用?grid-area?
屬性:
.header {
grid-area: h;
}
.menu {
grid-area: m;
}
.content {
grid-area: c;
}
.footer {
grid-area: f;
}
這樣就實現(xiàn)了上面的布局效果。
1.把 menu 移到右邊
grid-template-areas: “h h h h h h h h h h h h” "c c c c c c c c c c m m” “f f f f f f f f f f f f”;
實現(xiàn)后的效果:
2.使用點?.?
來創(chuàng)建空白的網(wǎng)格單元格
grid-template-areas: “. h h h h h h h h h h .” "c c c c c c c c c c m m” “. f f f f f f f f f f .”;
實現(xiàn)效果:
3.真正的響應式布局
假設你想在移動設備上查看的是:標題旁邊是菜單。那么你可以簡單地這樣做:
@media screen and (max-width: 640px) {
.container {
grid-template-areas:
"m m m m m m h h h h h h"
"c c c c c c c c c c c c"
"f f f f f f f f f f f f";
}
}
可以看到如下效果:
?
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/1076.html
摘要:繼續(xù)響應式網(wǎng)頁布局的實現(xiàn),今日講的是方案。就是為二維布局設計的,最適合用來做網(wǎng)頁布局。其中是最小寬度單位,等于六個等于三個等于兩個而則等于五個。 繼續(xù)W3Schools響應式網(wǎng)頁布局的實現(xiàn),今日講的是CSS Grid方案。CSS Grid就是為二維布局設計的,最適合用來做網(wǎng)頁布局。目前主流的瀏覽器都已經(jīng)支持CSS Grid,除非你很確定你的用戶常使用較舊的瀏覽器,不然的話,建議使用CS...
摘要:繼續(xù)響應式網(wǎng)頁布局的實現(xiàn),今日講的是方案。就是為二維布局設計的,最適合用來做網(wǎng)頁布局。其中是最小寬度單位,等于六個等于三個等于兩個而則等于五個。 繼續(xù)W3Schools響應式網(wǎng)頁布局的實現(xiàn),今日講的是CSS Grid方案。CSS Grid就是為二維布局設計的,最適合用來做網(wǎng)頁布局。目前主流的瀏覽器都已經(jīng)支持CSS Grid,除非你很確定你的用戶常使用較舊的瀏覽器,不然的話,建議使用CS...
摘要:的個值表示三列,相應的數(shù)值表示列寬即都為。嘗試其它布局把移到右邊實現(xiàn)后的效果使用點來創(chuàng)建空白的網(wǎng)格單元格實現(xiàn)效果真正的響應式布局假設你想在移動設備上查看的是標題旁邊是菜單。 常用Grid布局屬性介紹 下面從一個簡單Grid布局例子說起。 CSS Grid 布局由兩個核心組成部分是 wrapper(父元素)和 items(子元素)。 wrapper 是實際的 grid(網(wǎng)格),items...
閱讀 3138·2021-09-22 15:50
閱讀 3340·2021-09-10 10:51
閱讀 3154·2019-08-29 17:10
閱讀 2929·2019-08-26 12:14
閱讀 1846·2019-08-26 12:00
閱讀 962·2019-08-26 11:44
閱讀 660·2019-08-26 11:44
閱讀 2830·2019-08-26 11:41