博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CSS Grid布局:网格单元格布局
阅读量:6006 次
发布时间:2019-06-20

本文共 4541 字,大约阅读时间需要 15 分钟。

定义一个网格

<!doctype html>

<html>
<head>
<meta charset="UTF-8">
<title>test</title>
<meta name="description" content="">
<meta name="keywords" content="">
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.3, user-scalable=no">
<meta content="yes" name="apple-mobile-web-app-capable">
<meta content="black" name="apple-mobile-web-app-status-bar-style">
<meta content="telephone=no" name="format-detection">
<meta content="email=no" name="format-detection">
<style>
    *{margin:0;padding:0;}
    .clearfix{zoom:1;}
    .clearfix:after{content:'\20';display:block;height:0;clear:both;}
    body{font-size:62.5%;padding:50px;}
    .con1{
        display:grid;
        grid-template-columns:100px 10px 100px 10px 100px;
        grid-template-rows:auto 10px auto;
    }
    .ct{
        background:#ccc;
        color:#fff;
        font-size:2.0em;
        padding:20px;
    }
    .b,.d,.g,.i {
      background-color:red;
    }
</style>
</head>
<body>
<div class="con1">
    <div class="a ct">A</div>
    <div class="b ct">B</div>
    <div class="c ct">C</div>
    <div class="d ct">D</div>
    <div class="e ct">E</div>
    <div class="f ct">F</div>
    <div class="g ct">G</div>
    <div class="h ct">H</div>
    <div class="i ct">I</div>
    <div class="j ct">J</div>
</div>
</body>
</html>

 可以给父容器的display属性设置为grid或者inline-grid定义一个网格。这样你就可以使用grid-template-columnsgrid-template-rows属性来创建一个网格。

在这个示例中,创建了一个三列网格,其中三个列的列宽是100px,并且指定列与列之间的间距为10px。同时网格具有三行,每行的高度是自动的,另外行与行之间的间距是10px。简单点说就是一个三行三列的网格,并且列与列之间,行与行之间的间距都是10px

此时浏览器将容器中的子元素自动填入到每个网格单元格中,当超过指定的列数时,网格会自动换行,如下图所示:

定义网格的关键代码:

.wrapper { display: grid; grid-template-columns: 100px 10px 100px 10px 100px; grid-template-rows: auto 10px auto; } 从示例效果中可以看出,.wrapper容器通过display:grid;定义成网格,并且使用grid-template-columns:100px 10px 100px 10px 100px;和grid-template-rows:auto 10px auto;指定了列宽、列间距,行高和行间距等。对应的子元素.a、.c、.e、.f、.h和.j列宽度为100px(也就是黑色区域),而.b、.d、.g和.i是列与列的间距10px(也就是红色区域)。而且当子元素在一行填不下时,就会自动换行,如.f~.j自动换到第二行显示。

基于网格线的占位区

 

网格中的单元格是有网格线划分出来的,那么在网格布局中,同样可以使用网格线来给子元素设置占位区域。基于上例,在容器.wrapper下面有十个子元素.a~.j,接下来看如何通过基于网格线来实现各种在网格布局中的区域。

 

对于网格线,在网格布局中有两种,一种是列线,另一种是行线。对应的个网格单元格都有列线起始线(grid-column-start)、列线终止线(grid-column-end)和行线起始线(grid-row-start)、行线终止线(grid-row-end)。

 

网格线

 

如上图所示,紫色的是列网格线,而蓝色的是行网格线,其中高亮大红的那个单元格列起始线是line3,列终止线是line4,行起始线是line3,行终止线是line4。也就是说这四条网格线间的区域是一个单元格。

 

接下来,看一个示例,如何用网格线实现单元格占位区域:

   
test
.a{ grid-column-start: 1; grid-column-end: 2; grid-row-start: 1; grid-row-end: 2; } .b { grid-column-start: 3; grid-column-end: 4; grid-row-start: 1; grid-row-end: 2; } .c { grid-column-start: 5; grid-column-end: 6; grid-row-start: 1; grid-row-end: 2; } .d { grid-column-start: 7; grid-column-end: 8; grid-row-start: 1; grid-row-end: 2; } .e { grid-column-start: 1; grid-column-end: 2; grid-row-start: 3; grid-row-end: 4; } .f { grid-column-start: 3; grid-column-end: 4; grid-row-start: 3; grid-row-end: 4; } .g { grid-column-start: 5; grid-column-end: 6; grid-row-start: 3; grid-row-end: 4; } .h { grid-column-start: 7; grid-column-end: 8; grid-row-start: 3; grid-row-end: 4; } .i { grid-column-start: 1; grid-column-end: 2; grid-row-start: 5; grid-row-end: 6; } .j { grid-column-start: 3; grid-column-end: 4; grid-row-start: 5; grid-row-end: 6; }
   
A
B
C
D
E
F
G
H
I
J

网格线简写

 

前面两个示例向大家演示了如何用网格线实现布局,可以说是简单方便,唯一就是写代码麻烦,要什么grid-column-startgrid-column-end等等。其实有一种简写方式,可以让你不再痛苦。

 

网格线的简写方式,其实就是grid-columngrid-rowstartend值合并在一起,两者之间用/来分隔。比如:

 
.a{ grid-column-start: 1; grid-column-end: 2; grid-row-start: 1; grid-row-end: 2; }
 

可以写成:

 
.a{ grid-column: 1 / 2; grid-row: 1 / 2; }
 

网格区域实现元素占位区

 

在CSS Grid Layout中有一个关键东东,网格区域grid-area。网格区域他是由四条网格线组成的一个空间,简单点说,一个网格单元格也是一个网格区域(因为他也是有四条网格线组成的一个空间),多个单元格合并在一起也是一个网格区域。这样一来,要实现上例的效果,还可以使用网格区域grid-area来完成。

 

在具体做案例之前,先简单的了解,网格区域是由哪几条网格线组成。组成网格区域的网格线顺序是row-start/column-start/row-end/column-end。每个网格线之间也是使用/来分隔。

 
   
test
.a{ grid-area: 1 / 1 / 2 / 2; } .b { grid-area: 1 / 3 / 2 /4; } .c { grid-area: 1 / 5 / 2 / 6; } .d { grid-area: 1 / 7 / 2 / 8; } .e { grid-area: 3 / 1 / 4 / 2; } .f { grid-area: 3 / 3 / 4 / 4; } .g { grid-area: 3 / 5 / 4 / 6; } .h { grid-area: 3 / 7 / 4 / 8; } .i { grid-area: 5 / 1 / 6 / 2; } .j { grid-area: 5 / 3 / 6 / 4; }
   
A
B
C
D
E
F
G
H
I
J
 

转载于:https://www.cnblogs.com/zhp404/articles/4301867.html

你可能感兴趣的文章
libevent evbuffer参考文章
查看>>
用python爬取app照片
查看>>
ASP.NET状态管理
查看>>
软件工程中的瀑布模型和敏捷模型
查看>>
不做7件事,提高生产力
查看>>
PS小技巧之完美抠图
查看>>
一个Oracle触发器的示例
查看>>
《Photoshop CS5 The Missing Manual》 - 书摘精要
查看>>
HSQLDB 安装与使用
查看>>
Oracle 字符串分割排序冒泡算法
查看>>
深度学习与神经网络
查看>>
李小龙教给我们的敏捷开发之道
查看>>
windows 程序设计的一些总结
查看>>
细数AutoLayout以来UIView和UIViewController新增的相关API<转写>
查看>>
[转]SqlServer 表分区详细介绍
查看>>
02 栈(Stack)
查看>>
春季学期第六周作业
查看>>
字符串交叉插入
查看>>
项目总结
查看>>
codeforces #139 A dice tower
查看>>