博客
关于我
2-7 CSS布局3-Grid布局
阅读量:184 次
发布时间:2019-02-28

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

  • 一维布局flex:选择横向或者纵向
  • 二维布局grid:两个方向同时布局

1.容器 container

  • 成为container:在父元素上加 grid
.container{    display:grid;/*or inline-grid*/}
  • 设置父元素的行和列(称为新时代的表格)
    方法一:宽度划分
.container{     display: grid;  grid-template-columns: 40px 50px auto 50px 40px;  grid-template-rows:60px 300px 100px;  /*划分格子,行与列的宽度,三行五列*/  /*具体宽度根据格子划分的内容来定*/  }

方法二:份数划分(主要用来做平均布局)

.container{     display: grid;  grid-template-columns: 1fr 2fr 1fr;  grid-template-rows:1fr 1fr;  /*划分格子,行与列的份数,两行三列*/  /*份数可以自己随便调整*/  border:1px solid red;}

可以在任意连续格子中放div

在这里插入图片描述

项目 item

  • 设置范围(两种方法均按照线条命名来)
.a{     grid-row-start: 1;/*数字代表格子线,1表示第1根线*/  grid-row-end: 2;/*表示横向第1根到第2根线*/  grid-column-start: 1;  grid-column-end: 6;/*竖线是第1根到第6根*/}/*a来表示导航栏*/

平均布局

{   margin:0;padding:0;box-sizing: border-box;}.container{     display: grid;  grid-template-columns: 1fr 1fr 1fr 1fr;  grid-template-rows:1fr 1fr 1fr;  width: 800px;  border:1px solid red;  grid-gap: 12px;/*直接给出中间的宽度就会平均分布,包括上下左右*/}.image{     width: 191px;  height: 191px;  background: grey;}

高级技巧:grid-template-areas

直接用来快速搭建框架

header
main
ad
footer
{   margin:0;padding:0;box-sizing: border-box;}.container{     min-height: 100vh;/*最小高度占满整个屏幕*/  display: grid;  grid-template-rows: 60px auto 60px;/*设置每一行的高度*/  grid-template-columns: 100px auto 100px;/*设置每一列的宽度*/  grid-template-areas:    "header header header"    "aside main ad"    "footer . footer"  /*直接通过文字进行分区,非常方便,一一对一个*/  /*不想占居的空间直接用 . 来占位*/}.container>*{     border: 1px solid red;}/*星号表示container里面的所有内容*/.container> header{     grid-area: header;/*占据所有命名为header的区域*/}.container> aside{     grid-area: aside;/*占据所有命名为header的区域*/}.container> .ad{     grid-area: ad;/*占据所有命名为header的区域*/}.container> footer{     grid-area: footer;/*占据所有命名为header的区域*/}

间隙 gap

.container{    grid-column-gap: 10px;/*竖直方向间隙*/ grid-row-gap: 10px;}

案例

不规则布局

在这里插入图片描述

*{   margin:0;padding: 0; box-sizing:border-box;}.demo{     display: inline-grid;/*内联元素,可以包裹住小范围内容,不会扩展全行*/  border: 1px solid red;  grid-template-rows: 240px repeat(4,120px);  /*4个120px重复*/  grid-template-columns:250px 250px;  grid-template-areas:    "big mid1"    "big mid2"    "sm1 mid2"    "sm2 mid3"    "sm3 mid3";}.demo > .image:first-child{     grid-area: big;  border: 1px solid red;}.demo > .image:nth-child(2){     grid-area: sm1;  border: 1px solid red;}.demo > .image:nth-child(3){     grid-area: sm2;  border: 1px solid red;}.demo > .image:nth-child(4){     grid-area: sm3;  border: 1px solid red;}.demo > .image:nth-child(5){     grid-area: mid1;  border: 1px solid red;}.demo > .image:nth-child(6){     grid-area: mid2;  border: 1px solid red;}.demo > .image:nth-child(7){     grid-area: mid3;  border: 1px solid red;}

转载地址:http://xfvi.baihongyu.com/

你可能感兴趣的文章
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
MySQL 导出数据
查看>>