css新特性 css-Gird布局

一.概述:

网格布局(Grid)是最强大的 CSS 布局方案;
它将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局。以前,只能通过复杂的 CSS 框架达到的效果,现在浏览器内置了
在这里插入图片描述
容器里面的水平区域称为"行"(row),垂直区域称为"列"(column)
在这里插入图片描述

二.容器和项目

 <div id="box">
        <span>这是Gaid布局</span>
        <div id="container">
            <div class="item item-1">1</div>
            <div class="item item-2">2</div>
            <div class="item item-3">3</div>
            <div class="item item-4">4</div>
            <div class="item item-5">5</div>
            <div class="item item-6">6</div>
            <div class="item item-7">7</div>
            <div class="item item-8">8</div>
        </div>
    </div

采用网格布局的区域,称为"容器"(container)。容器内部采用网格定位的子元素,称为"项目"(item)
上面代码中,idcontainer为元素就是容器,内层的8个< div >元素就是项目

三.容器属性

在这里插入图片描述

 #container{
        display:grid;

    }

容器指定了网格布局以后,接着就要划分行和列。grid-template-columns属性定义每一列的列宽,grid-template-rows属性定义每一行的行高

 #container{
        display:grid;
        /*  grid-template-columns :第一个40%表示第一个元素,后面有几个元素一行就会有几个元素 */
        grid-template-columns:  40% 25% 15% 20% ;   //也可以单独使用绝对单位如px
       /* 下面代码指定了一个四行四列的网格,高都是50% */
        grid-template-rows: 50% 50% 50% 50%; 
    }

在这里插入图片描述

(1)repeat()

有时候,重复写同样的值非常麻烦,尤其网格很多时。这时,可以使用repeat()函数,简化重复的值。上面的代码用repeat()改写如下

 #container{
        display:grid;
        grid-template-columns:repeat(4,25%) ;  
        grid-template-rows: repeat(4,50%); 

    }

在这里插入图片描述
1.repeat()接受两个参数,第一个参数是重复的次数,第二个参数是所要重复的值。

2.repeat()重复某种模式也是可以的

(2)auto-fill 关键字

有时,单元格的大小是固定的,但是容器的大小不确定。如果希望每一行(或每一列)容纳尽可能多的单元格,这时可以使用auto-fill关键字表示自动填充

#container{
        grid-template-columns:repeat(auto-fill,100px) ;  
    }

在这里插入图片描述

(3)auto-fill 关键字

为了方便表示比例关系,网格布局提供了fr关键字(fraction 的缩写,意为"片段")。如果两列的宽度分别为1fr和2fr,就表示后者是前者的两倍

 #container{
        grid-template-columns: 1fr 1fr 1fr 1fr ;  
        //上面表示两个相同宽度的列
    }

在这里插入图片描述
fr可以与绝对长度的单位结合使用,这时会非常方便

#container{
        grid-template-columns: 150px 1fr 1fr ;  
    }

在这里插入图片描述

(4)minmax()

minmax()函数产生一个长度范围,表示长度就在这个范围之中。它接受两个参数,分别为最小值和最大值

 #container{
        grid-template-columns: 1fr 1fr minmax(100px, 1fr)  
    }

在这里插入图片描述
面代码中,minmax(100px, 1fr)表示列宽不小于100px,不大于1fr

(5)auto 关键字

auto关键字表示由浏览器自己决定长度

 #container{
        grid-template-columns: 100px auto 100px;
    }

在这里插入图片描述

(6)布局实例

grid-template-columns属性对于网页布局非常有用。两栏式布局只需要一行代码

#container{
        grid-template-columns: 70% 30%
    }

在这里插入图片描述
上面代码将左边栏设为70%,右边栏设为30%

传统的8网格布局,写起来也很容易

 #container{
        grid-template-columns: repeat(8, 1fr)
    }

在这里插入图片描述

后缀gap 属性

grid-row-gap ;
grid-column-gap ;
grid-gap

grid-row-gap属性设置行与行的间隔(行间距),grid-column-gap属性设置列与列的间隔(列间距)

 #container{
        grid-template-columns: repeat(3, 1fr);
        row-gap: 20px;  //每一行之间间隔20px
        column-gap: 40px;  //每一列之间间隔40px
        
	//grid-gap属性是column-gap和row-gap的合并简写形式,语法如下
	//也可以写成下面这样,效果一致
	.container {
	  grid-gap: 20px 40px;
	}
    }

在这里插入图片描述

grid-template-areas 属性

网格布局允许指定"区域"(area),一个区域由单个或多个单元格组成。grid-template-areas属性用于定义区域

#container{
        grid-template-columns:100px 100px 100px ;
        grid-template-rows:100px 100px 100px; 
        grid-template-areas: 'a b c'
                       'd e f'
                       'g h i';
    }

上面代码先划分出9个单元格,然后将其定名为a到i的九个区域,分别对应这九个单元格

grid-auto-flow 属性

划分网格以后,容器的子元素会按照顺序,自动放置在每一个网格。默认的放置顺序是"先行后列",即先填满第一行,再开始放入第二行,即下图数字的顺序

这个顺序由grid-auto-flow属性决定,默认值是row,即"先行后列"。也可以将它设成column,变成"先列后行"

在这里插入图片描述
这个顺序由grid-auto-flow属性决定,默认值是row,即"先行后列"。也可以将它设成column,变成"先列后行

设置了column以后,放置顺序就变成了下图
在这里插入图片描述

后缀items 属性,

1.justify-items

2.align-items

3.place-items

justify-items属性设置单元格内容的水平位置(左中右),align-items属性设置单元格内容的垂直位置(上中下)

justify-items: start | end | center | stretch;
align-items: start | end | center | stretch;

#container{
        display:grid;
    	 justify-items: start | end | center | stretch;
	  	align-items: start | end | center | stretch;
    }
    

下面图片一次是,start,center,end 对齐效果
在这里插入图片描述

 justify-items: stretch   
 表示项目大小没有指定时,拉伸占据整个网格容器

在这里插入图片描述

justify-content 属性, align-content 属性, place-content 属性

.container {
justify-content: start | end | center | stretch | space-around | space-between | space-evenly;

align-content: start | end | center | stretch | space-around | space-between | space-evenly;
}

#container{
        display:grid;
        grid-template-columns: repeat( 3,20%);
        grid-template-areas: 'a b c'
                            'd e f'
                            'g h i';  
    }
 #container{
        justify-content: start;

    }

在这里插入图片描述

 #container{
        justify-content: center;
    }

在这里插入图片描述

#container{
        justify-content: end;
    }

在这里插入图片描述

stretch - 项目大小没有指定时,拉伸占据整个网格容器。
在这里插入图片描述
space-around - 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍
在这里插入图片描述

space-between - 项目与项目的间隔相等,项目与容器边框之间没有间隔
在这里插入图片描述
space-evenly - 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔

在这里插入图片描述

四.感谢阮一峰作者

本文参照阮一峰作者的素材,以下是原文作者的地址:
http://www.ruanyifeng.com/blog/2019/03/grid-layout-tutorial.html
阮一峰作者博客包含的内容详述的更深刻和详细,请大家可以去看看

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值