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 相关文章推荐
纯css3实现的鼠标悬停动画按钮
Dec 23 HTML / CSS
CSS3区域模块region相关编写示例
Aug 28 HTML / CSS
css3实现二维码扫描特效的示例
Oct 29 HTML / CSS
HTML5实时语音通话聊天MP3压缩传输3KB每秒
Aug 28 HTML / CSS
Javascript 高级手势使用介绍
Apr 21 HTML / CSS
HTML5学习笔记之History API
Feb 26 HTML / CSS
Html5+JS实现手机摇一摇功能
Apr 24 HTML / CSS
利用HTML5 Canvas制作键盘及鼠标动画的实例分享
Mar 15 HTML / CSS
浅谈关于html5中图片抛物线运动的一些心得
Jan 09 HTML / CSS
canvas实现烟花的示例代码
Jan 16 HTML / CSS
html5 移动端视频video的android兼容(去除播放控件、全屏)
Mar 26 HTML / CSS
html5关于外链嵌入页面通信问题(postMessage解决跨域通信)
Jul 20 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
PHP队列用法实例
2014/11/05 PHP
PHP加密解密实例分析
2015/12/25 PHP
PHP-FPM实现性能优化
2016/03/31 PHP
一个挺有意思的Javascript小问题说明
2011/09/26 Javascript
javascript针对DOM的应用分析(四)
2012/04/15 Javascript
值得分享的Bootstrap Ace模板实现菜单和Tab页效果
2015/12/30 Javascript
JavaScript添加随滚动条滚动窗体的方法
2016/02/23 Javascript
AngularJS 避繁就简的路由
2016/07/01 Javascript
微信小程序Server端环境配置详解(SSL, Nginx HTTPS,TLS 1.2 升级)
2017/01/12 Javascript
浅谈JavaScript正则表达式-非捕获性分组
2017/03/08 Javascript
JavaScript实现跟随滚动缓冲运动广告框
2017/07/15 Javascript
React如何利用相对于根目录进行引用组件详解
2017/10/09 Javascript
Vue 2.5.2下axios + express 本地请求404的解决方法
2018/02/21 Javascript
简单了解小程序+node梳理登陆流程
2019/06/24 Javascript
vue前后分离调起微信支付
2019/07/29 Javascript
vue实现设置载入动画和初始化页面动画效果
2019/10/28 Javascript
[00:12]2018DOTA2亚洲邀请赛 Sccc亮相SOLO赛,今年他又会有什么样的战绩?
2018/04/06 DOTA
python遍历文件夹,指定遍历深度与忽略目录的方法
2018/07/11 Python
对sklearn的使用之数据集的拆分与训练详解(python3.6)
2018/12/14 Python
Python3.8中使用f-strings调试
2019/05/22 Python
Django基础知识 web框架的本质详解
2019/07/18 Python
win7下 python3.6 安装opencv 和 opencv-contrib-python解决 cv2.xfeatures2d.SIFT_create() 的问题
2019/10/24 Python
python爬虫模块URL管理器模块用法解析
2020/02/03 Python
python filecmp.dircmp实现递归比对两个目录的方法
2020/05/22 Python
Under Armour澳大利亚官网:美国知名的高端功能性运动品牌
2018/02/22 全球购物
Kingsoft金山公司C/C++笔试题
2016/05/10 面试题
幼儿园教师节活动方案
2014/02/02 职场文书
会计岗位职责范本
2014/03/07 职场文书
广告词串烧
2014/03/19 职场文书
环卫工人先进事迹材料
2014/06/02 职场文书
办理房产过户的委托书
2014/09/14 职场文书
会计工作能力自我评价
2015/03/05 职场文书
mysql事务隔离级别详情
2021/10/24 MySQL
日本动漫十大公认神作:第五现已全网禁播,《死亡笔记》在榜
2022/03/18 日漫
Java实现经典游戏泡泡堂的示例代码
2022/04/04 Java/Android
Elasticsearch 批量操作
2022/04/19 Python