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教程(2):网页边框半径和网页圆角
Apr 02 HTML / CSS
CSS3 选择器 基本选择器介绍
Jan 21 HTML / CSS
CSS3——齿轮转动关键代码
May 02 HTML / CSS
纯CSS实现颜色渐变效果(包含环形渐变、线性渐变、彩虹效果等)
May 07 HTML / CSS
在HTML5中如何使用CSS建立不可选的文字
Oct 17 HTML / CSS
html5指南-2.如何操作document metadata
Jan 07 HTML / CSS
html5贪吃蛇游戏使用63行代码完美实现
Jun 25 HTML / CSS
详解Html5 监听拦截Android返回键方法
Apr 18 HTML / CSS
canvas实现滑动验证的实现示例
Aug 11 HTML / CSS
使用HTML和CSS实现的标签云效果(附demo)
Feb 03 HTML / CSS
css让页脚保持在底部位置的四种方案
Jul 23 HTML / CSS
CSS实现鼠标悬浮动画特效
May 07 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 Memcached应用实现代码
2010/02/08 PHP
浅谈PHP强制类型转换,慎用!
2013/06/06 PHP
php实现阿拉伯数字和罗马数字相互转换的方法
2015/04/17 PHP
php类常量用法实例分析
2015/07/09 PHP
Yii2中多表关联查询hasOne hasMany的方法
2017/02/15 PHP
PHP实现的pdo连接数据库并插入数据功能简单示例
2019/03/30 PHP
jQuery实现form表单reset按钮重置清空表单功能
2012/12/18 Javascript
解析Javascript中大括号“{}”的多义性
2013/12/02 Javascript
JavaScript数值数组排序示例分享
2014/05/27 Javascript
Js数组排序函数sort()介绍
2015/06/08 Javascript
Bootstrap在线电子商务网站实战项目5
2016/10/14 Javascript
微信小程序 高德地图SDK详解及简单实例(源码下载)
2017/01/11 Javascript
vue.js的提示组件
2017/03/02 Javascript
React Native使用百度Echarts显示图表的示例代码
2017/11/07 Javascript
Mac中安装nvm的教程分享
2017/12/11 Javascript
浅谈微信小程序flex布局基础
2018/09/10 Javascript
js正则取值的结果数组调试方法
2018/10/10 Javascript
React事件处理的机制及原理
2018/12/03 Javascript
Vue 之孙组件向爷组件通信的实现
2019/04/23 Javascript
Jquery异步上传文件代码实例
2019/11/13 jQuery
详解ES6中class的实现原理
2020/10/03 Javascript
Vue实现手机号、验证码登录(60s禁用倒计时)
2020/12/19 Vue.js
零基础写python爬虫之抓取百度贴吧代码分享
2014/11/06 Python
python3获取当前文件的上一级目录实例
2018/04/26 Python
python学生信息管理系统(初级版)
2018/10/17 Python
python中import与from方法总结(推荐)
2019/03/21 Python
Pytorch反向求导更新网络参数的方法
2019/08/17 Python
python中调试或排错的五种方法示例
2019/09/12 Python
Python实现一个简单的毕业生信息管理系统的示例代码
2020/06/08 Python
HTML5实现无刷新修改URL的方法
2019/11/14 HTML / CSS
欧洲最大的滑雪假期供应商之一:Sunweb Holidays
2018/01/06 全球购物
如何掌握自荐信格式呢
2013/11/19 职场文书
体育专业大学生职业生涯规划范文:打造自己的运动帝国
2014/09/12 职场文书
小学班主任工作总结2015
2015/04/07 职场文书
2016年教师党员承诺书范文
2016/03/24 职场文书
golang中切片copy复制和等号复制的区别介绍
2021/04/27 Golang