博客列表 >Css gird布局基础属性(栅格布局)

Css gird布局基础属性(栅格布局)

星夜低语
星夜低语原创
2020年04月14日 18:02:38878浏览

Grid 布局

测试地址,请老师查看~

准备工作

  • 编辑器: VSCODE
  • 浏览器: FireFox
  • 浏览器同步插件: Live Server

1. 基本术语

  • 容器: 使用网格布局的元素
  • 项目: 容器中的子元素
  • 网格线: 将容器划分为行与列的直线
  • 显式网络: 由用户根据项目数量指示容器生成的网格
  • 隐式网格: 由容器根据项目数量自动生成的网格
  • 单元格: 项目放置的具体空间
  • 网格区域: 一个以上的单元格组成的矩形区域

网格布局的基本步骤: 1. 生成网格; 2. 放置项目


2. 创建 Grid 容器

  • display: 声明使用网格布局的容器元素
  • grid-auto-flow: 声明项目在网格中自动填充方案(行优先/列优先)
  • grid-template-columns/rows: 在容器中显式地划分行与列,生成指定数量的单元格来放置项目
  • grid-auto-rows/columns: 根据项目数量,在容器中隐式生成行与列来放置它们

3. 设置单元格数量与尺寸

  • 固定宽度px: 固定大小
  • 百分比%: 以容器大小为依据来计算
  • 自动计算auto: 由浏览器决定长度
  • 比例fr: 将容器空间按比例分配给每一个单元格
  • 区间minmax(min,max): 设置单元格尺寸变化范围
  • 重复生成repeat(): 快速生成相同大小单元格的
  • 自动填充auto-fill: 单元格固定,但容器不确定时,可以让一行/列容纳尽可能多的项目

4. 将项目填充到指定单元格中

4.1 使用默认网格线划分单元格

  • 默认从左上角开始,从左到右,从上到下,依次从 1 开始编号
  • 如果从右下角开始,由下向上,由右向左,依次由从-1 开始编号
  • 根据数字网格线,可以将项目放到网格线形成的封闭矩形区域中

4.2 使用命名网格线划分单元格

  • 使用语义化的名称替代容器自动生成的数字网线线编号
  • 同一条网络线可以有多个别名

4.3 重复设置单元格时, 命名网格线会自动添加索引

  • repeat(3, [col-start] 100px [col-end]): 只需设置命名前缀,编号会自动生成
  • grid-column-end: col-end 3;: 前缀加索引就可以引用到自动生成的命名网格线

测试代码

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>设置单元格在容器中的对齐方式</title>
  7. <style>
  8. body {
  9. color: #fff;
  10. text-align: center;
  11. }
  12. .container {
  13. /* 创建grid容器 */
  14. display: grid;
  15. width: 400px;
  16. height: 400px;
  17. grid-auto-flow: row;
  18. /* 固定值 */
  19. grid-template-columns: 100px 100px 100px;
  20. grid-template-rows: 100px 100px 100px;
  21. /* 百分比 */
  22. grid-template-columns: 33.333% 33.333% 33.333%;
  23. grid-template-rows: 33.333% auto 33.333%;
  24. /* 比例 */
  25. grid-template-columns: 2fr 2fr 2fr;
  26. grid-template-rows: 1fr auto 1fr;
  27. /* 重复设置 */
  28. grid-template-columns: repeat(3, 100px);
  29. grid-template-rows: repeat(3, 100px);
  30. /* 按分组来设置: (50px-100px) */
  31. /* 50px 100px 50px 100px */
  32. grid-template-columns: repeat(2, 50px 100px);
  33. /* 弹性 */
  34. grid-template-columns: repeat(2, minmax(50px, 100px));
  35. grid-template-rows: repeat(3, minmax(150px, 1fr));
  36. /* 自动填充 */
  37. grid-template-columns: repeat(auto-fill, 100px);
  38. grid-template-rows: repeat(auto-fill, 100px);
  39. gap: 5px;
  40. }
  41. .container > .item {
  42. background: lightgrey;
  43. padding: 30px;
  44. }
  45. .container .item:nth-child(even) {
  46. background: skyblue;
  47. }
  48. .item.item1 {
  49. background-color: lightgreen;
  50. grid-row-start: 1;
  51. grid-row-end: 2;
  52. grid-column-start: 2;
  53. grid-column-end: 3;
  54. }
  55. .item.item5 {
  56. /* 简写 */
  57. background-color: lightgreen;
  58. grid-row: 2 / 3;
  59. grid-column: 2 / 3;
  60. }
  61. /* 使用偏移量来简化, 将第三个移动到左下角 */
  62. .item.item5 {
  63. background-color: yellow;
  64. grid-row-end: span 2;
  65. /* grid-column-start: 3; */
  66. grid-column-end: span 2;
  67. }
  68. /* ************************** */
  69. /* 使用命名网格线来划分单元格 */
  70. .table1 {
  71. width: 400px;
  72. height: 400px;
  73. background-color: burlywood;
  74. /* 创建grid容器 */
  75. display: grid;
  76. grid-template-columns: [c1-start] 100px [c1-end c2-start] 100px [c2-end c3-start] 100px [c3-end];
  77. grid-template-rows: [r1-start] 100px [r1-end r2-start] 100px [r2-end r3-start] 100px [r3-end];
  78. gap: 5px;
  79. }
  80. .ta.ta1 {
  81. background-color: lightgreen;
  82. /* 默认就是跨越一行/一列,所以可以省略 */
  83. grid-row-start: r1-start;
  84. grid-column-start: c2-start;
  85. }
  86. .ta.ta5 {
  87. background-color: lightpink;
  88. /* grid-row: r1-start / r2-start;
  89. grid-column: c1-start / c3-end; */
  90. grid-column-end: span 3;
  91. }
  92. </style>
  93. </head>
  94. <body>
  95. <div class="container">
  96. <div class="item item1">1</div>
  97. <div class="item item2">2</div>
  98. <div class="item item3">3</div>
  99. <div class="item item4">4</div>
  100. <div class="item item5">5</div>
  101. <div class="item item6">6</div>
  102. <div class="item item7">7</div>
  103. <div class="item item8">8</div>
  104. <div class="item item9">9</div>
  105. </div>
  106. </body>
  107. </html>

效果图

5. 将项目填充到网格区域中

5.1 默认网格区域

  • 设置项目属性grid-area: 将项目填充到指定容器的区域中
  • 语法: grid-area: 起始行 / 起始列 / 结束行 / 结束列

5.2 命名网格区域

  • 可以为每一个网格区域设置一个语义化的名称
  • 具有名称的网络区域称之为命名区域
  • 名称相同的网格区域会合并, 形成更大的区域空间
  • 项目设置的区域名称后,会自动填充到容器中应对的命名区域中

5.3 网格区域占位符

  • 当项目默认已到填充到正确的区域中,无需设置时,可使用”.”做为占位符

5.4 命名网格区域线默认名称

  • 区域起始行/列: 区域名称-start, 如header-start / header-start,表示区域起始行/区域起始列
  • 区域结束行/列: 区域名称-end,如header-end / header-end,表示区域结束行/区域结束列

6. 设置所有项目在容器中的对齐方式

  • justify-content: 设置所有项目在容器中水平方向的对齐方式
  • align-content: 设置所有项目在容器中垂直方向的对齐方式
  • place-content: 上面二个属性的简写, place-content: 垂直对齐方式 水平对齐方式

7. 设置所有项目在单元格或网格区域内的对齐方式

  • justify-items: 设置所有项目在单元格/网格区域中水平方向的对齐方式
  • align-items: 设置所有项目在单元格/网格区域中垂直方向的对齐方式
  • place-items: 上面二个属性的简写, place-items: 垂直对齐方式 水平对齐方式
  • demo11.html: 所有项目在单元格中的对齐方式

8. 设置某个项目在单元格或网格区域内的对齐方式

  • justify-self: 设置某个项目在单元格/网格区域中水平方向的对齐方式
  • align-self: 设置某个项目在单元格/网格区域中垂直方向的对齐方式
  • place-self: 上面二个属性的简写, place-self: 垂直对齐方式 水平对齐方式

9. 设置容器中行与列之间的间距/间隙

  • column-gap: 列间距
  • row-gap: 行间距
  • gap: 行间距 列间距: 简写
  • gap: 值: 行与列相等,可只写一个值

个人总结

Css Grid布局可以理解为 表格去记忆,具有相似之处,可以更加灵活的对html页面进行布局,使html页面更加简洁便于维护。颠覆我对布局的认识几行代码就可以完成一个页面的结构布局

特别注意其中有的属性与flex的一样容易混淆多练孰能生巧

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议