CSS Grid 網格佈局教程css
grid 佈局就是給父元素(容器)添加display:grid
,而後使子元素(項目)改變佈局,html
1 2 3 4 5 6 7 8 9web
上面九個正方形的代碼以下:沒有給正方形設定寬度,是爲了方便觀察css效果函數
.seven{佈局
background:#f1c40f;ui
line-height:100px;spa
color:#fff;scala
font-size: 40px;code
text-align: center;htm
}
grid-template-columns
屬性 | grid-template-rows
屬性
grid-template-columns
定義每一列的列寬
grid-template-rows
定義每一行的行高
單位有:fr(分數)、%、px
.section-one-1{
width:400px;
display: grid;
grid-template-columns: 1fr 1fr 1fr;
grid-template-rows: 1fr 1fr 1fr;
}
把九個宮格分紅了三行三列,每個項目的空間佔1/3*1/3=1/9
若是容器的寬度沒有限定,就會以容器最大的寬度來等比例排列
.section-one-2{
display: grid;
grid-template-columns: 1fr 1fr 1fr;
grid-template-rows: 1fr 1fr 1fr;
}
justify-items
屬性|align-items
屬性|place-items
屬性
justify-items
屬性設置單元格內容的水平位置(左中右 默認)start | center | end | stretch;
align-items
屬性設置單元格內容的垂直位置(上中下 默認)start | center | end | stretch;
place-items
屬性是align-items
屬性和justify-items
屬性的合併簡寫形式。
place-items: align-items(start) justify-items(end)
當容器寬度大於項目的集合寬度,當容器高度大於項目的集合高度,項目會自動居中在每兩列之間,以下代碼
.section-two-1 {
display: grid;
grid-template-columns: repeat(3,1fr);
grid-template-rows: repeat(3,1fr);
place-items: center center;
height:500px;
}
grid-row-gap
屬性|grid-column-gap
屬性|grid-gap
屬性
grid-row-gap
屬性設置行與行的間隔(行間距)
grid-column-gap
屬性設置列與列的間隔(列間距)
grid-gap
屬性是grid-row-gap
和grid-column-gap
的合併簡寫形式
grid-gap: grid-row-gap grid-column-gap
.section-three-1{
display: grid;
grid-template-columns: repeat(3,1fr);
grid-template-rows: repeat(3,1fr);
grid-row-gap: 20px;
grid-column-gap: 30px;
}
grid-template-areas
屬性 |grid-area
屬性網格佈局容許指定"區域"(area),一個區域由單個或多個單元格組成。grid-template-areas
屬性用於定義區域
這個屬性須要搭配項目(兒子)的grid-area
屬性使用
grid-area
屬性指定項目放在哪個區域。
.section-four-1{
display: grid;
grid-template-columns: 150px 150px 150px;
grid-template-rows:150px 150px 150px;
grid-template-areas
:"header header header""header header header"
"two three four";
}
.section-four-1>span:first-child{
grid-area
: header;}
.section-four-1>span:nth-child(2){
grid-area
: two;}
.section-four-1>span:nth-child(3){
grid-area
: three;}
.section-four-1>span:last-child{
grid-area
: four;}
repeat()
函數repeat 函數做用在能夠把重複的簡寫,代碼以下。第一個參數爲重複的次數,第二個參數是重複的數值
.section-five-1{
width:500px;
display: grid;
grid-template-columns: repeat(3,1fr);
grid-template-rows: repeat(3,1fr);
}
repeat()
重複某種模式也是能夠的。
以下圖定義了6列,第一列和第四列的寬度爲100px,第二列和第五列爲220px,第三列和第六列爲1fr。
.section-five-2{
display: grid;
grid-template-columns:repeat(2,100px 220px 1fr);
grid-template-rows: repeat(3,1fr);
}
minmax(min,max)
函數minmax(min,max)
函數產生一個長度範圍,表示長度就在這個範圍之中。它接受兩個參數,分別爲最小值和最大值。
.section-six-1{
display: grid;
grid-template-columns:1fr 1fr minmax(50px, 100px);
grid-template-rows: 1fr 1fr minmax(50px, 150px);
}
grid-auto-flow
屬性grid-auto-flow
屬性決定,默認值是row,即"先行後列"。也能夠將它設成column,變成"先列後行"。
.section-seven-1{
display: grid;
grid-template-columns:repeat(3,1fr);
grid-template-rows:repeat(3,1fr);
grid-auto-flow: column;
}
justify-content
屬性|align-content
屬性|place-content
屬性justify-content
屬性是整個內容區域在容器裏面的水平位置(左中右)start | end | center | stretch | space-around | space-between | space-evenly;
align-content
屬性是整個內容區域的垂直位置(上中下)start | end | center | stretch | space-around | space-between | space-evenly;
place-content
屬性:align-content justify-content
justify-content
屬性值只能體如今grid-template-columns
中某一個值爲auto纔會有效果。以下
.section-eight-1{
display: grid;
grid-template-columns:150px auto 150px;
grid-template-rows:repeat(3,1fr);
place-items: center center;
height: 500px;
justify-content: start;
}
justify-content:stretch;
恢復默認狀況。以下
.section-eight-2{
display: grid;
grid-template-columns:150px auto 150px;
grid-template-rows:repeat(3,1fr);
place-items: center center;
height: 500px;
justify-content:stretch;
}
justify-content:space-around;
每一個項目兩側的間隔相等。因此,項目之間的間隔比項目與容器邊框的間隔大一倍。以下
.section-eight-3{
display: grid;
grid-template-columns:150px auto 150px;
grid-template-rows:repeat(3,1fr);
place-items: center center;
height: 500px;
justify-content:space-around;
}
justify-content:space-between;
項目與項目的間隔相等,項目與容器邊框之間沒有間隔。以下
.section-eight-4{
display: grid;
grid-template-columns:150px auto 150px;
grid-template-rows:repeat(3,1fr);
place-items: center center;
height: 500px;
justify-content:space-between;
}
justify-content:space-evenly;
項目與項目的間隔相等,項目與容器邊框之間也是一樣長度的間隔。以下
.section-eight-5{
display: grid;
grid-template-columns:150px auto 150px;
grid-template-rows:repeat(3,1fr);
place-items: center center;
height: 500px;
justify-content:space-evenly;
}
align-content
屬性和justify-content
屬性是同樣的
grid-column-start
屬性 | grid-column-end
屬性grid-row-start
屬性 | grid-row-end
屬性這些屬性定義在項目上面.
grid-column-start
屬性:左邊框所在的垂直網格線
grid-column-end
屬性:右邊框所在的垂直網格線
grid-row-start
屬性:上邊框所在的水平網格線
grid-row-end
屬性:下邊框所在的水平網格線
.section-nine-1{
width:400px;
display:grid;
grid-template-columns: repeat(3,1fr);
grid-template-rows: repeat(3,1fr);
}
.section-nine-1>span:first-child{
grid-column-start: 2;
grid-column-end: 4;
}
1號項目的左邊框是第二根垂直網格線,右邊框是第四根垂直網格線。以下
上圖中,只指定了1號項目的左右邊框,沒有指定上下邊框,因此會採用默認位置,即上邊框是第一根水平網格線,下邊框是第二根水平網格線。
下面的例子是指定四個邊框位置的效果。
1號項目的左邊框是第1根垂直網格線,右邊框是第3根垂直網格線。上邊框是第2根水平網格線,下邊框是第4根水平垂直線。以下
.section-nine-2{
width:400px;
display:grid;
grid-template-columns: repeat(3,1fr);
grid-template-rows: repeat(3,1fr);
}
.section-nine-2>span:first-child{
grid-column-start: 1;
grid-column-end: 3;
grid-row-start: 2;
grid-row-end: 4;
}
這四個屬性的值還可使用span
關鍵字,表示"跨越",即左右邊框(上下邊框)之間跨越多少個網格。
上面代碼表示,1號項目的左邊框距離右邊框跨越3個網格。上邊框距離下邊框跨越2個網格
.section-nine-3{
width:400px;
display:grid;
grid-template-columns: repeat(3,1fr);
grid-template-rows: repeat(3,1fr);
}
.section-nine-3>span:first-child{
grid-column-start:span 3;
grid-row-start:span 2;
}
grid-column
屬性 | grid-row
屬性grid-column
屬性是grid-column-start
和grid-column-end
的合併簡寫形式
grid-row
屬性是grid-row-start
屬性和grid-row-end
的合併簡寫形式。
.section-nine-3>span:first-child{
grid-column-start:1/3;
grid-row:2/4;
}
.section-nine-3>span:first-child{
grid-column-start: 1;
grid-column-end: 3;
grid-row-start: 2;
grid-row-end: 4;
}
justify-self
屬性 | align-self
屬性 | place-self
屬性justify-self
屬性設置單元格內容的水平位置(左中右),跟justify-items
屬性的用法徹底一致,但只做用於單個項目。
justify-self
屬性設置單元格內容的垂直位置(上中下),跟align-items
屬性的用法徹底一致,也是隻做用於單個項目。
place-self
屬性是align-self
屬性和justify-self
屬性的合併簡寫形式。
若是省略第二個值,place-self
屬性會認爲這兩個值相等。
place-self: (align-self) (justify-self);
兩個屬性均可以取四個值。start:對齊單元格的起始邊緣。 end:對齊單元格的結束邊緣。
center:單元格內部居中。stretch:拉伸,佔滿單元格的整個寬度(默認值)。
.section-ten-1{
width:400px;
display:grid;
grid-template-columns: repeat(3,1fr);
grid-template-rows: repeat(3,1fr);
}
.section-ten-1>span:first-child{
justify-self: start;
}
header{ margin:20px 0; text-align: center; font-size: 30px; color:#2ecc71; } .section-1{ margin:20px 0; } .one{ /*width:100px;*/ /*height:100px;*/ background: #1abc9c; color:#fff; font-size: 40px; text-align: center; line-height:100px; } .two{ /*width:100px;*/ /*height:100px;*/ background: #2ecc71; color:#fff; font-size: 40px; text-align: center; line-height:100px; } .three{ /*width:100px;*/ /*height:100px;*/ background: #3498db; color:#fff; font-size: 40px; text-align: center; line-height:100px; } .four{ /*width:100px;*/ /*height:100px;*/ background: #9b59b6; color:#fff; font-size: 40px; text-align: center; line-height:100px; } .five{ /*width:100px;*/ /*height:100px;*/ background:#34495e; color:#fff; font-size: 40px; text-align: center; line-height:100px; } .six{ /*width:100px;*/ /*height:100px;*/ background:#ff9966; color:#fff; font-size: 40px; text-align: center; line-height:100px; } .seven{ /*width:100px;*/ /*height:100px;*/ background:#f1c40f; color:#fff; font-size: 40px; text-align: center; line-height:100px; } .eight{ /*width:100px;*/ /*height:100px;*/ background: #e67e22; color:#fff; font-size: 40px; text-align: center; line-height:100px; } .nine{ /*width:100px;*/ /*height:100px;*/ background: #e74c3c; color:#fff; font-size: 40px; text-align: center; line-height:100px; } .section-one-1{ width:400px; display:grid; grid-template-columns: 1fr 1fr 1fr; grid-template-rows: 1fr 1fr 1fr; } .section-one-2{ display:grid; grid-template-columns:1fr 1fr 1fr; grid-template-rows: 1fr 1fr 1fr; } .section-two-1 { display: grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(3, 1fr); place-items: center center; height:500px; } .section-three-1{ display: grid; grid-template-columns: repeat(3,1fr); grid-template-rows: repeat(3,1fr); grid-row-gap: 20px; grid-column-gap: 30px; } .section-four-1{ display: grid; grid-template-columns: 150px 150px 150px; grid-template-rows: 150px 150px 150px; grid-template-areas:"header header header" "header header header" "two three four"; } .section-four-1>span:first-child{ grid-area: header; } .section-four-1>span:nth-child(2){ grid-area: two; } .section-four-1>span:nth-child(3){ grid-area: three; } .section-four-1>span:last-child{ grid-area: four; } .section-five-1{ width:500px; display:grid; grid-template-columns: repeat(3,1fr); grid-template-rows: repeat(3,1fr); } .section-five-2{ display: grid; grid-template-columns: repeat(2,100px 220px 1fr); grid-template-rows: repeat(3,1fr); } .section-six-1{ display: grid; grid-template-columns:1fr 1fr minmax(50px, 100px); grid-template-rows:1fr 1fr minmax(50px, 150px); } .section-seven-1{ display: grid; grid-template-columns:repeat(3,1fr); grid-template-rows:repeat(3,1fr); grid-auto-flow: column; } .section-eight-1{ display: grid; grid-template-columns: 150px auto 150px; grid-template-rows: repeat(3, 1fr); place-items: center center; height: 500px; justify-content: start; } .section-eight-2{ display: grid; grid-template-columns: 150px auto 150px; grid-template-rows: repeat(3, 1fr); place-items: center center; height: 500px; justify-content: stretch; } .section-eight-3{ display: grid; grid-template-columns: 150px auto 150px; grid-template-rows: repeat(3, 1fr); place-items: center center; height: 500px; justify-content: space-around; } .section-eight-4{ display: grid; grid-template-columns: 150px auto 150px; grid-template-rows: repeat(3, 1fr); place-items: center center; height: 500px; justify-content: space-between; } .section-eight-5{ display: grid; grid-template-columns: 150px auto 150px; grid-template-rows: repeat(3, 1fr); place-items: center center; height: 500px; justify-content: space-evenly; } .section-nine-1{ width:400px; display:grid; grid-template-columns: repeat(3,1fr); grid-template-rows: repeat(3,1fr); } .section-nine-1>span:first-child{ grid-column-start: 2; grid-column-end: 4; } .section-nine-2{ width:400px; display:grid; grid-template-columns: repeat(3,1fr); grid-template-rows: repeat(3,1fr); } .section-nine-2>span:first-child{ grid-column-start: 1; grid-column-end: 3; grid-row-start: 2; grid-row-end: 4; } .section-nine-3{ width:400px; display:grid; grid-template-columns: repeat(3,1fr); grid-template-rows: repeat(3,1fr); } .section-nine-3>span:first-child{ grid-column-start: span 3; grid-row-start: span 2; } .section-ten-1{ width:400px; display:grid; grid-template-columns: repeat(3,1fr); grid-template-rows: repeat(3,1fr); } .section-ten-1>span:first-child{ justify-self: start; }
*{ margin:0; padding:0; font-family: '幼圓'; } ::selection{ color:#fff; background: #1abc9c; } html::-webkit-scrollbar { width: 13px; height: 13px; } html::-webkit-scrollbar-thumb { background: -webkit-gradient(linear,left top,left bottom,from(#2ecc71),to(#27ae60)); background: linear-gradient(to bottom,#2ecc71,#27ae60); border-radius: 30px; -webkit-box-shadow: inset 2px 2px 2px rgba(255,255,255,.25), inset -2px -2px 2px rgba(0,0,0,.25); box-shadow: inset 2px 2px 2px rgba(255,255,255,.25), inset -2px -2px 2px rgba(0,0,0,.25); } html::-webkit-scrollbar-track { background: linear-gradient(to right,#95a5a6,#95a5a6 1px,#7f8c8d 1px,#7f8c8d); } .container-1200{ width:1200px; margin:0 auto; } h1{ color:#2ecc71; text-align: center; } li{ list-style: none; } span{ display: inline-block; } code{ display: inline-block; padding-left: 5px; padding-right: 5px; font-size: 120%; background-color: pink; border-radius: 5px; margin: auto 3px; color:#111; } blockquote{ background-color: #f5f2f0; padding: 1em; margin: 2em 2em; -moz-border-radius: 1em; -webkit-border-radius: 1em; border-radius: 1em; border-width: 0.3em; border-color: #e0dfcc; border-style: solid; text-shadow: 0 1px white; overflow: auto; } blockquote div{ width:39%; float: left; } blockquote img{ width:29%; float: left; } b{ color:red; font-size: 20px; } p{ /*font-family: '微軟雅黑';*/ margin:10px 0; font-weight:600; font-size: 16px; }
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>CSS Grid 網格佈局教程</title> <link rel="stylesheet" href="/css/public.css"> <link rel="stylesheet" href="/css/grid.css"> </head> <body class="container-1200"> <section> <header>CSS Grid 網格佈局教程</header> <h2>grid 兼容性查看請點此處 <a style="color:red;font-weight:800;" href="https://caniuse.com/#search=grid">最新Grid兼容</a></h2> <p>grid 佈局就是給父元素(容器)添加<code>display:grid</code>,而後使子元素(項目)改變佈局,</p> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </section> <p>上面九個正方形的代碼以下:沒有給正方形設定寬度,是爲了方便觀察css效果</p> <blockquote> <p>.seven{</p> <p> background:#f1c40f;</p> <p>line-height:100px;</p> <p>color:#fff;</p> <p>font-size: 40px;</p> <p> text-align: center;</p> <p>}</p> </blockquote> <section class="section-1"> <p><h1>1.<code>grid-template-columns</code> 屬性 | <code>grid-template-rows</code> 屬性</h1></p> <p><code>grid-template-columns</code> 定義每一列的列寬</p> <p><code>grid-template-rows</code> 定義每一行的行高</p> <p>單位有:fr(分數)、%、px</p> <blockquote> <div> <p>.section-one-1{</p> <p>width:400px;</p> <p>display: grid;</p> <p>grid-template-columns: 1fr 1fr 1fr;</p> <p>grid-template-rows: 1fr 1fr 1fr;</p> <p>}</p> </div> <img src="/image/grid/1.png" alt=""> </blockquote><p>把九個宮格分紅了三行三列,每個項目的空間佔1/3*1/3=1/9</p> <div class="section-one-1"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <p>若是容器的寬度沒有限定,就會以容器最大的寬度來等比例排列</p> <blockquote> <div> <p>.section-one-2{</p> <p>display: grid;</p> <p>grid-template-columns: 1fr 1fr 1fr;</p> <p>grid-template-rows: 1fr 1fr 1fr;</p> <p>}</p> </div> <img style="width:50%;" src="/image/grid/2.png" alt=""> </blockquote> <div class="section-one-2"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> </section> <section class="section-1"> <p><h1>2.若是要使容器內項目居中,則可以使用<code>justify-items</code>屬性|<code>align-items</code> 屬性|<code>place-items</code> 屬性</h1></p> <p><code>justify-items</code>屬性設置單元格內容的水平位置(左中右 默認)<b>start | center | end | stretch</b>;</p> <p><code>align-items</code>屬性設置單元格內容的垂直位置(上中下 默認)<b>start | center | end | stretch</b>;</p> <p><code>place-items</code>屬性是<code>align-items</code>屬性和<code>justify-items</code> 屬性的合併簡寫形式。</p> <blockquote> <p>place-items: align-items(start) justify-items(end)</p> </blockquote> <p>當容器寬度大於項目的集合寬度,當容器高度大於項目的集合高度,項目會自動居中在每兩列之間,以下代碼</p> <blockquote> <div> <p>.section-two-1 {</p> <p>display: grid;</p> <p>grid-template-columns: repeat(3,1fr);</p> <p>grid-template-rows: repeat(3,1fr);</p> <p>place-items: center center;</p> <p>height:500px;</p> <p>}</p> </div> <img style="width:50%;" src="/image/grid/3.png" alt=""> </blockquote> <div class="section-two-1"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> </section> <section class="section-1"> <p><h1>3.<code>grid-row-gap</code> 屬性|<code>grid-column-gap</code> 屬性|<code>grid-gap</code> 屬性</h1></p> <p><code>grid-row-gap</code> 屬性設置行與行的間隔(行間距)</p> <p><code>grid-column-gap</code> 屬性設置列與列的間隔(列間距)</p> <p><code>grid-gap</code>屬性是<code>grid-row-gap</code>和<code>grid-column-gap</code>的合併簡寫形式</p> <blockquote> <p>grid-gap: grid-row-gap grid-column-gap</p> </blockquote> <blockquote> <div> <p>.section-three-1{</p> <p>display: grid;</p> <p>grid-template-columns: repeat(3,1fr);</p> <p>grid-template-rows: repeat(3,1fr);</p> <p>grid-row-gap: 20px;</p> <p> grid-column-gap: 30px;</p> <p>}</p> </div> <img style="width:61%;" src="/image/grid/4.png" alt=""> </blockquote> <div class="section-three-1"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> </section> <section class="section-1"> <h1>4.<code>grid-template-areas</code>屬性 |<code>grid-area</code>屬性</h1> <p>網格佈局容許指定"區域"(area),一個區域由單個或多個單元格組成。<code>grid-template-areas</code>屬性用於定義區域</p> <p>這個屬性須要搭配項目(兒子)的<code>grid-area</code>屬性使用</p> <p><code>grid-area</code>屬性指定項目放在哪個區域。</p> <blockquote> <div> <p>.section-four-1{</p> <p>display: grid;</p> <p>grid-template-columns: 150px 150px 150px;</p> <p>grid-template-rows:150px 150px 150px;</p> <p><code>grid-template-areas</code>:"header header header"</p> <p>"header header header"</p> <p>"two three four";</p> <p>}</p> <p>.section-four-1>span:first-child{</p> <p><code>grid-area</code>: header;</p> <p>}</p> <p>.section-four-1>span:nth-child(2){</p> <p><code>grid-area</code>: two;</p> <p>}</p> <p>.section-four-1>span:nth-child(3){</p> <p><code>grid-area</code>: three;</p> <p>}</p> <p>.section-four-1>span:last-child{</p> <p><code>grid-area</code>: four;</p> <p>}</p> </div> <img style="width:50%;" src="/image/grid/5.png" alt=""> </blockquote> <div class="section-four-1"> <span class="header"><img style="width:450px;height:300px" src="/image/grid/four-1.jpg" alt=""></span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> </div> </section> <section class="section-1"> <h1>5.<code>repeat()</code> 函數</h1> <p>repeat 函數做用在能夠把重複的簡寫,代碼以下。第一個參數爲重複的次數,第二個參數是重複的數值</p> <blockquote> <div> <p>.section-five-1{</p> <p>width:500px;</p> <p>display: grid;</p> <p>grid-template-columns: repeat(3,1fr);</p> <p>grid-template-rows: repeat(3,1fr);</p> <p>}</p></div> <img src="/image/grid/6.png" alt=""> </blockquote> <div class="section-five-1"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <p><code>repeat()</code>重複某種模式也是能夠的。</p> <p>以下圖定義了6列,第一列和第四列的寬度爲100px,第二列和第五列爲220px,第三列和第六列爲1fr。</p> <blockquote> <div> <p>.section-five-2{</p> <p>display: grid;</p> <p>grid-template-columns:repeat(2,100px 220px 1fr);</p> <p>grid-template-rows: repeat(3,1fr);</p> <p>}</p> </div> <img style="width:50%;" src="/image/grid/7.png" alt=""> </blockquote> <div class="section-five-2"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> </section> <section class="section-1"> <h1>6.<code>minmax(min,max)</code> 函數</h1> <p><code>minmax(min,max)</code> 函數產生一個長度範圍,表示長度就在這個範圍之中。它接受兩個參數,分別爲最小值和最大值。</p> <blockquote> <div> <p>.section-six-1{</p> <p>display: grid;</p> <p>grid-template-columns:1fr 1fr minmax(50px, 100px);</p> <p>grid-template-rows: 1fr 1fr minmax(50px, 150px);</p> <p>}</p> </div> <img style="width:60%;" src="/image/grid/8.png" alt=""> </blockquote> <div class="section-six-1"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> </section> <section class="section-1"> <h1>7.<code>grid-auto-flow</code> 屬性</h1> <p><code>grid-auto-flow</code>屬性決定,默認值是row,即"先行後列"。也能夠將它設成column,變成"先列後行"。</p> <blockquote> <div> <p>.section-seven-1{</p> <p>display: grid;</p> <p>grid-template-columns:repeat(3,1fr);</p> <p>grid-template-rows:repeat(3,1fr);</p> <p>grid-auto-flow: column;</p> <p>}</p> </div> </blockquote> <div class="section-seven-1"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> </section> <section class="section-1"> <h1>8.<code>justify-content</code>屬性|<code>align-content</code>屬性|<code>place-content</code>屬性</h1> <p><code>justify-content</code>屬性是整個內容區域在容器裏面的水平位置(左中右)start | end | center | stretch | space-around | space-between | space-evenly;</p> <p><code>align-content</code>屬性是整個內容區域的垂直位置(上中下)start | end | center | stretch | space-around | space-between | space-evenly;</p> <p><code>place-content</code>屬性:align-content justify-content</p> <p><code>justify-content</code>屬性值只能體如今<code>grid-template-columns</code>中某一個值爲auto纔會有效果。以下</p> <blockquote> <div> <p>.section-eight-1{</p> <p>display: grid;</p> <p>grid-template-columns:150px auto 150px;</p> <p>grid-template-rows:repeat(3,1fr);</p> <p>place-items: center center;</p> <p>height: 500px;</p> <p>justify-content: start;</p> <p>}</p> </div> <img style="width:20%;" src="/image/grid/9.png" alt=""> </blockquote> <div class="section-eight-1"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <p><code>justify-content:stretch;</code>恢復默認狀況。以下</p> <blockquote> <div> <p>.section-eight-2{</p> <p>display: grid;</p> <p>grid-template-columns:150px auto 150px;</p> <p>grid-template-rows:repeat(3,1fr);</p> <p>place-items: center center;</p> <p>height: 500px;</p> <p>justify-content:stretch;</p> <p>}</p> </div> <img style="width:50%;" src="/image/grid/10.png" alt=""> </blockquote> <div class="section-eight-2"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <p><code>justify-content:space-around;</code>每一個項目兩側的間隔相等。因此,項目之間的間隔比項目與容器邊框的間隔大一倍。以下</p> <blockquote> <div> <p>.section-eight-3{</p> <p>display: grid;</p> <p>grid-template-columns:150px auto 150px;</p> <p>grid-template-rows:repeat(3,1fr);</p> <p>place-items: center center;</p> <p>height: 500px;</p> <p>justify-content:space-around;</p> <p>}</p> </div> <img style="width:50%;" src="/image/grid/11.png" alt=""> </blockquote> <div class="section-eight-3"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <p><code>justify-content:space-between;</code>項目與項目的間隔相等,項目與容器邊框之間沒有間隔。以下</p> <blockquote> <div> <p>.section-eight-4{</p> <p>display: grid;</p> <p>grid-template-columns:150px auto 150px;</p> <p>grid-template-rows:repeat(3,1fr);</p> <p>place-items: center center;</p> <p>height: 500px;</p> <p>justify-content:space-between;</p> <p>}</p> </div> <img style="width:50%;" src="/image/grid/12.png" alt=""> </blockquote> <div class="section-eight-4"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <p><code>justify-content:space-evenly;</code>項目與項目的間隔相等,項目與容器邊框之間也是一樣長度的間隔。以下</p> <blockquote> <div> <p>.section-eight-5{</p> <p>display: grid;</p> <p>grid-template-columns:150px auto 150px;</p> <p>grid-template-rows:repeat(3,1fr);</p> <p>place-items: center center;</p> <p>height: 500px;</p> <p>justify-content:space-evenly;</p> <p>}</p> </div> <img style="width:50%;" src="/image/grid/13.png" alt=""> </blockquote> <div class="section-eight-5"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <p><code>align-content</code>屬性和<code>justify-content</code>屬性是同樣的</p> </section> <section class="section-1"> <h1>9. <code>grid-column-start</code> 屬性 | <code>grid-column-end</code> 屬性 </h1> <h1><code>grid-row-start</code> 屬性 | <code>grid-row-end</code> 屬性</h1> <p>這些屬性定義在項目上面.</p> <p><code>grid-column-start</code>屬性:左邊框所在的垂直網格線</p> <p><code>grid-column-end</code>屬性:右邊框所在的垂直網格線</p> <p><code>grid-row-start</code>屬性:上邊框所在的水平網格線</p> <p><code>grid-row-end</code>屬性:下邊框所在的水平網格線</p> <blockquote> <div> <p>.section-nine-1{</p> <p>width:400px;</p> <p>display:grid;</p> <p>grid-template-columns: repeat(3,1fr);</p> <p>grid-template-rows: repeat(3,1fr);</p> <p>}</p> <p>.section-nine-1>span:first-child{</p> <p>grid-column-start: 2;</p> <p>grid-column-end: 4;</p> <p>}</p> </div> <img style="width:43%;" src="/image/grid/14.png" alt=""> </blockquote> <p>1號項目的左邊框是第二根垂直網格線,右邊框是第四根垂直網格線。以下</p> <div class="section-nine-1"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <p>上圖中,只指定了1號項目的左右邊框,沒有指定上下邊框,因此會採用默認位置,即上邊框是第一根水平網格線,下邊框是第二根水平網格線。</p> <p>下面的例子是指定四個邊框位置的效果。</p> <p>1號項目的左邊框是第1根垂直網格線,右邊框是第3根垂直網格線。上邊框是第2根水平網格線,下邊框是第4根水平垂直線。以下</p> <blockquote> <div> <p>.section-nine-2{</p> <p>width:400px;</p> <p>display:grid;</p> <p>grid-template-columns: repeat(3,1fr);</p> <p>grid-template-rows: repeat(3,1fr);</p> <p>}</p> <p>.section-nine-2>span:first-child{</p> <p>grid-column-start: 1;</p> <p>grid-column-end: 3;</p> <p>grid-row-start: 2;</p> <p>grid-row-end: 4;</p> <p>}</p> </div> <img style="width:51%;" src="/image/grid/15.png" alt=""> </blockquote> <div class="section-nine-2"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <p>這四個屬性的值還可使用<code>span</code>關鍵字,表示"跨越",即左右邊框(上下邊框)之間跨越多少個網格。</p> <p>上面代碼表示,1號項目的左邊框距離右邊框跨越3個網格。上邊框距離下邊框跨越2個網格</p> <blockquote> <div> <p>.section-nine-3{</p> <p>width:400px;</p> <p>display:grid;</p> <p>grid-template-columns: repeat(3,1fr);</p> <p>grid-template-rows: repeat(3,1fr);</p> <p>}</p> <p>.section-nine-3>span:first-child{</p> <p>grid-column-start:span 3;</p> <p>grid-row-start:span 2;</p> <p>}</p> </div> <img style="width:31%;" src="/image/grid/16.png" alt=""> </blockquote> <div class="section-nine-3"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> <h1><code>grid-column</code> 屬性 | <code>grid-row</code> 屬性</h1> <p><code>grid-column</code>屬性是<code>grid-column-start</code>和<code>grid-column-end</code>的合併簡寫形式</p> <p><code>grid-row</code>屬性是<code>grid-row-start</code>屬性和<code>grid-row-end</code>的合併簡寫形式。</p> <blockquote> <div> <p>.section-nine-3>span:first-child{</p> <p>grid-column-start:1/3;</p> <p>grid-row:2/4;</p> <p>}</p> <p>.section-nine-3>span:first-child{</p> <p>grid-column-start: 1;</p> <p>grid-column-end: 3;</p> <p>grid-row-start: 2;</p> <p>grid-row-end: 4;</p> <p>}</p> </div> </blockquote> </section> <section class="section-1"> <h1>10.<code>justify-self</code> 屬性 | <code>align-self</code> 屬性 | <code>place-self</code> 屬性</h1> <p><code>justify-self</code>屬性設置單元格內容的水平位置(左中右),跟<code>justify-items</code>屬性的用法徹底一致,但只做用於單個項目。</p> <p><code>justify-self</code>屬性設置單元格內容的垂直位置(上中下),跟<code>align-items</code>屬性的用法徹底一致,也是隻做用於單個項目。</p> <p><code>place-self</code>屬性是<code>align-self</code>屬性和<code>justify-self</code>屬性的合併簡寫形式。</p> <p>若是省略第二個值,<code>place-self</code>屬性會認爲這兩個值相等。</p> <blockquote> <p>place-self: (align-self) (justify-self);</p> </blockquote> <p>兩個屬性均可以取四個值。start:對齊單元格的起始邊緣。 end:對齊單元格的結束邊緣。</p> <p>center:單元格內部居中。stretch:拉伸,佔滿單元格的整個寬度(默認值)。</p> <blockquote> <div> <p>.section-ten-1{</p> <p>width:400px;</p> <p>display:grid;</p> <p>grid-template-columns: repeat(3,1fr);</p> <p>grid-template-rows: repeat(3,1fr);</p> <p>}</p> <p>.section-ten-1>span:first-child{</p> <p> justify-self: start;</p> <p>}</p> </div> <img style="width:37%;" src="/image/grid/17.png" alt=""> </blockquote> <div class="section-ten-1"> <span class="one">1</span> <span class="two">2</span> <span class="three">3</span> <span class="four">4</span> <span class="five">5</span> <span class="six">6</span> <span class="seven">7</span> <span class="eight">8</span> <span class="nine">9</span> </div> </section> </body> </html>