溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

發(fā)布時(shí)間:2021-05-26 11:54:20 來源:億速云 閱讀:423 作者:Leah 欄目:web開發(fā)

今天就跟大家聊聊有關(guān)如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

1.網(wǎng)格布局(grid):

        它將網(wǎng)頁劃分成一個(gè)個(gè)網(wǎng)格,可以任意組合不同的網(wǎng)格,做出各種各樣的布局;

2.基本概念

        容器和項(xiàng)目,如圖所示:

<div class="content">
        <div class="b">1</div>
        <div class="b">2</div>
        <div class="b">3</div>
        <div class="b">4</div>
        <div class="b">5</div>
        <div class="b">6</div>
        <div class="b">7</div>
        <div class="b">8</div>
        <div class="b">9</div>
    </div>

        .content即為容器,.b即為項(xiàng)目。

        行和列:        行:row;

        列:column;

如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

3.容器屬性

        display:grid;            //默認(rèn)是塊元素;

        display:inline-grid;         //行內(nèi)塊元素

        指定一個(gè)容器采用網(wǎng)格布局;

如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局   

        注意:設(shè)置為grid后,子元素的float,display: inline-block,display: table-cell、vertical-align和column-*等設(shè)置都將失效。

.content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-columns: 100px 100px 100px;
            grid-template-rows: 100px 100px 100px;
        }

4.屬性解釋

        grid-template-columns:定義每一列的列寬;

        grid-template-columns:100px 100px 100px;      //總共三列,每列列寬是100px;=

        grid-template-rows:定義每一行的行高;

        grid-template-rows:100px 100px 100px;        //從上至下,每行高度為100px;

        //除了使用像素,還可以使用百分比;

        拓展:

            重復(fù)寫值很麻煩,可以用repeate函數(shù);

            repeat(次數(shù),大小);

            例如:repeat(3,100px);            //重復(fù)3次,每次100px;

        repeat寫法:

        grid-template-columns:repeat(3,100px);

        grid-template-rows:repeat(3,100px);

        也可以重復(fù)某一種不固定大小模式;

        例如:

        grid-template-columns:100px 80px 100px;        

        改寫成:

        grid-template-columns:repeat(2,100px 80px);    //代表重復(fù)2次100px 80px的模式;也就是4列;

        等同于:

        grid-template-columns:100px 80px 100px 80px;

        如圖: 

如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

5.關(guān)鍵字

        1,auto-fill;如果容器大小不固定,項(xiàng)目大小固定,可以用auto-fill關(guān)鍵字自動(dòng)填充;

.content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-columns: repeat(auto-fill, 100px);
}   

 如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

      2,fr(fraction):如果兩列的寬度分別為1fr和2fr,就表示后者是前者的兩倍。

   .content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-columns: 1fr 2fr;
            grid-template-rows: repeat(3, 100px 80px);
}

   如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

   fr也可以和px配合使用;

.content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-columns: 400px 1fr 2fr;
}

     如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

 3.minmax();

      grid-template-columns: 1fr 5fr minmax(100px, 1fr);

      解釋:第一列是1fr,第二列是5fr,第三列最小值是100px,最大是1fr。當(dāng)?shù)诙衒r無限大時(shí)和第三列到100px時(shí),會(huì)往第一列借值;

   .content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-columns: 1fr 5fr minmax(100px, 1fr);
}

      4.auto:自適應(yīng);

   .content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-columns: 100px auto 100px;
}

  如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

6.網(wǎng)格線名稱:

.content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-columns: [c1] 100px [c2] 100px [c3] auto [c4];
            grid-template-rows: [r1] 100px [r2] 100px [r3] auto [r4];
}

        解釋:指定每一根網(wǎng)格線的名字,方便以后的引用。

        也可以有多個(gè)名字;[c1,c1a]

7.間距

      row-gap:行間距;

 .content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-columns: 100px 100px 100px;
            grid-template-rows: 100px 100px 100px;
            row-gap: 20px;
}

    如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

      colum-gap:列間距; 

 .content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-columns: 100px 100px 100px;
            grid-template-rows: 100px 100px 100px;
            column-gap: 20px;
}

      如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

簡寫:

      gap:20px 20px;

      row-gap和column-gap簡寫形式;

      gap省略了第二個(gè)值,瀏覽器認(rèn)為第二個(gè)值等于第一個(gè)值。

8.區(qū)域

  grid-template-areas:網(wǎng)格布局允許指定"區(qū)域"(area),一個(gè)區(qū)域由單個(gè)或多個(gè)單元格組成。grid-template-areas屬性用于定義區(qū)域。

  .content {
            box-shadow: 0 0 1px #f6f;
            display: grid;
            grid-template-areas: 'a b c' 'd e f' 'g h i';
        }

 如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局

看完上述內(nèi)容,你們對(duì)如何在CSS3中使用display:grid實(shí)現(xiàn)網(wǎng)格布局有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI