首页 > 其他 > 详细

grid 布局(2)

时间:2019-12-29 15:55:46      阅读:89      评论:0      收藏:0      [点我收藏+]

grid 布局(2)

grid区域属性

网格线名称

grid-template-columnsgrid-template-rows 属性里面,还可以使用方括号指定每一根网格线的名字,方便以后引用

例:

.container{
    display:grid;
    grid-template-columns: [a1] 100px [a2] 100px [a3] 100px [a4];
    grid-template-rows: [r1] 100px [r2] 100px [r3] 100px [r4];
}

上面的代码指定网格布局为 3*3 ,因此会有4根垂直网格线和4根水平网格线

网格布局允许一个网格线上有多个名字,比如[fifth-line row-5];

grid-template-areas 属性

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

.container{
    display:grid;
    grid-template-columns: repeat(3,100px);
    grid-template-rows: repeat(3,100px);
    grid-template-areas:'a b c'
                        'd e f'
                        'g h i';
}
完整代码 ```html Document
1
2
3
4
5
6
7
8
9
```

技术分享图片

上面代码就是9个单元格,子元素虽然是按照1-9的顺序书写的html代码,可是我在每个子元素上设置他们对应的grid-area坐标,他们就会去相应的地点。

实例布局

示例代码 ```html Document
header
aside
main
```

技术分享图片

通过区域实现的一种响应式布局

在区域中可以使用.这个来占位,代表这个位置没有东西,空白

示例代码 ```html Document
header
aside
main
```

技术分享图片

上面的方法通过grid属性模拟栅栏布局,来实现各种功能。而这个响应式的实现,不再是需要使用html+css实现aside的移动,而只需要改变css中的grid-areas属性即可实现

而这样纯css代码实现div的移动,我们可称之为源代码的独立性,即html只是用来标记内容,css来设计样式。

tip:最后补充一点 区域的命名会影响到网格线,每个区域的起始网格线会自动命名为"区域名-start",终止网格线自动命名为"区域名-end"。

grid-auto-flow

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

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

column : 1 4 7     row : 1 2 3
         2 5 8           4 5 6
         3 6 9           7 8 9

grid-auto-flow属性除了设置成row和column,还可以设成 row dense 和 columns dense。 这两个值主要用于,某些项目指定位置以后,剩下的项目怎么放置

row dense : 先填满横行,尽量不出现空格
column dense : 先填满列,尽量不出现空格

容器内子元素的属性

项目的位置是可以指定的,具体方法就是指定项目的四个边框,分别定位在哪根网络线

grid-column-start : 左边框所在的垂直网格线
grid-column-end : 右边框所在的垂直网格线
grid-row-start : 上边框所在的水平网格线
grid-row-start : 下边框所在的水平网格线

例:

    .item1{
        grid-column-start:2;
        grid-column-end:4;
    }
    /*起始于第二根网格线,第四根垂直网格线结束*/

grid 布局(2)

原文:https://www.cnblogs.com/strongtyf/p/12115132.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!