加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

CSS3中的display:grid布局怎样实施,效果是怎样的

发布时间:2023-10-06 14:52:08 所属栏目:语言 来源:
导读:这篇文章给大家分享的是CSS3中的display:grid布局怎样实现,效果是怎样的。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看
这篇文章给大家分享的是CSS3中的display:grid布局怎样实现,效果是怎样的。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
 
1.网格布局(grid):
 
        它将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局;
 
2.基本概念:
 
        容器和项目,
 
    <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即为项目。
 
        行和列:        行:row;
 
        列:column;

3.容器属性
 
        display:grid;            //默认是块元素;
 
        display:inline-grid;         //行内块元素
 
        指定一个容器采用网格布局;

        注意:设置为grid后,子元素的float,display: inline-block,display: table-cell、vertical-align和column-*等设置都将失效。
 
.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;
 
        //除了使用像素,还可以使用百分比;
 
        拓展:
 
            重复写值很麻烦,可以用repeate函数;
 
            repeat(次数,大小);
 
            例如:repeat(3,100px);            //重复3次,每次100px;
 
        repeat写法:
 
        grid-template-columns:repeat(3,100px);
 
        grid-template-rows:repeat(3,100px);
 
        也可以重复某一种不固定大小模式;
 
        例如:
 
        grid-template-columns:100px 80px 100px;        
 
        改写成:
 
        grid-template-columns:repeat(2,100px 80px);    //代表重复2次100px 80px的模式;也就是4列;
 
        等同于:
 
        grid-template-columns:100px 80px 100px 80px;
 
5.关键字
 
        1,auto-fill;如果容器大小不固定,项目大小固定,可以用auto-fill关键字自动填充;
    .content {
 
            box-shadow: 0 0 1px #f6f;
 
            display: grid;
 
            grid-template-columns: repeat(auto-fill, 100px);
 
}   
 
      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);
 
}
 
   fr也可以和px配合使用;

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

 3.minmax();
 
      grid-template-columns: 1fr 5fr minmax(100px, 1fr);
 
      解释:第一列是1fr,第二列是5fr,第三列最小值是100px,最大是1fr。当第二列fr无限大时和第三列到100px时,会往第一列借值;

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

6.网格线名称:
 
        .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];
 
}
 
        解释:指定每一根网格线的名字,方便以后的引用。
 
        也可以有多个名字;[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;
 
}

      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;
 
}
 
简写:
 
      gap:20px 20px;
 
      row-gap和column-gap简写形式;
 
      gap省略了第二个值,浏览器认为第二个值等于第一个值。
 
8.区域
 
  grid-template-areas:网格布局允许指定"区域"(area),一个区域由单个或多个单元格组成。grid-template-areas属性用于定义区域。
 
  .content {
 
            box-shadow: 0 0 1px #f6f;
 
            display: grid;
 
            grid-template-areas: 'a b c' 'd e f' 'g h i';
 
        }
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章