CSS3中的display:grid,网格布局介绍


Posted in HTML / CSS onOctober 30, 2019

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;

CSS3中的display:grid,网格布局介绍

3.容器属性

display:grid;

//默认是块元素;

display:inline-grid;

 //行内块元素

指定一个容器采用网格布局;

CSS3中的display: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;

如图: 

CSS3中的display:grid,网格布局介绍

5.关键字

1,auto-fill;如果容器大小不固定,项目大小固定,可以用auto-fill关键字自动填充;

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

 CSS3中的display:grid,网格布局介绍

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,网格布局介绍

 

 fr也可以和px配合使用;

 

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

 CSS3中的display:grid,网格布局介绍

 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;
}

CSS3中的display:grid,网格布局介绍

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;
}

CSS3中的display:grid,网格布局介绍

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,网格布局介绍

简写:

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';
        }

 CSS3中的display:grid,网格布局介绍

总结

以上所述是小编给大家介绍的CSS3中的display:grid,网格布局介绍,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

HTML / CSS 相关文章推荐
纯DOM+CSS3实现简单的小风车动画
Sep 27 HTML / CSS
CSS3中文字镂空、透明值、阴影效果设置示例小结
Mar 07 HTML / CSS
css3新增颜色表示方式分享
Apr 15 HTML / CSS
css3实现文字扫光渐变动画效果的示例
Nov 07 HTML / CSS
CSS3 Flex 弹性布局实例代码详解
Nov 01 HTML / CSS
详解css position 5种不同的值的用法
Jul 30 HTML / CSS
详解canvas在圆弧周围绘制文本的两种写法
May 22 HTML / CSS
使用html2canvas实现浏览器截图的示例代码
Jan 26 HTML / CSS
html5时钟实现代码
Oct 22 HTML / CSS
详解webapp页面滚动卡顿的解决办法
Dec 26 HTML / CSS
CSS实现五种常用的2D转换
Dec 06 HTML / CSS
开发微信小程序之WXSS样式教程
Apr 18 HTML / CSS
使用CSS3实现SVG路径描边动画效果入门教程
Oct 21 #HTML / CSS
CSS3 实现footer 固定在底部(无论页面多高始终在底部)
Oct 15 #HTML / CSS
CSS实现雨滴动画效果的实例代码
Oct 08 #HTML / CSS
CSS3 @media的基本用法总结
Sep 10 #HTML / CSS
css3 伪类选择器快速复习小结
Sep 10 #HTML / CSS
css3进阶之less实现星空动画的示例代码
Sep 10 #HTML / CSS
CSS3 animation ? steps 函数详解
Aug 30 #HTML / CSS
You might like
德劲1104的电路分析与改良
2021/03/01 无线电
根据判断浏览器类型屏幕分辨率自动调用不同CSS的代码
2007/02/22 Javascript
jQuery生成asp.net服务器控件的代码
2010/02/04 Javascript
DOM_window对象属性之--clipboardData对象操作代码
2011/02/03 Javascript
JS多物体 任意值 链式 缓冲运动
2012/08/10 Javascript
一个jquery实现的不错的多行文字图片滚动效果
2014/09/28 Javascript
js读取cookie方法总结
2014/10/31 Javascript
使用JS获取当前地理位置方法汇总
2014/12/18 Javascript
jQuery中:eq()选择器用法实例
2014/12/29 Javascript
jquery简单的弹出层浮动层代码
2015/04/27 Javascript
JavaScript中 this 指向问题深度解析
2017/02/21 Javascript
angular4中关于表单的校验示例
2017/10/16 Javascript
vue裁切预览组件功能的实现步骤
2018/05/04 Javascript
JS获取当前时间的实例代码(昨天、今天、明天)
2018/11/13 Javascript
浏览器事件循环与vue nextTicket的实现
2019/04/16 Javascript
JQuery实现简单的复选框树形结构图示例【附源码下载】
2019/07/16 jQuery
[02:38]DOTA2英雄基础教程 噬魂鬼
2014/01/03 DOTA
[01:15:18]2014 DOTA2国际邀请赛中国区预选赛 LGD VS Speed Gaming.cn
2014/05/22 DOTA
[25:59]Newbee vs TNC 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
urllib2自定义opener详解
2014/02/07 Python
python进阶教程之循环对象
2014/08/30 Python
python微信跳一跳系列之棋子定位颜色识别
2018/02/26 Python
python super的使用方法及实例详解
2019/09/25 Python
Django1.11配合uni-app发起微信支付的实现
2019/10/12 Python
django 获取字段最大值,最新的记录操作
2020/08/09 Python
奥地利顶级内衣丝袜品牌英国站:Wolford英国
2016/08/29 全球购物
定制iPhone和Macbook保护壳:Slick Case
2018/11/21 全球购物
Nordgreen手表德国官方网站:丹麦极简主义手表
2019/10/31 全球购物
static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?
2015/02/22 面试题
承诺书格式
2014/06/03 职场文书
咖啡店创业计划书
2014/08/15 职场文书
幼儿园六一儿童节主持词
2015/06/30 职场文书
六一儿童节新闻稿
2015/07/17 职场文书
餐厅服务员管理制度
2015/08/05 职场文书
不要在HTML中滥用div
2021/05/08 HTML / CSS
一篇文章告诉你如何实现Vue前端分页和后端分页
2022/02/18 Vue.js