Grid 布局

文章目录

  • 容器属性
    • display 属性
    • grid-template-columns 和 grid-template-rows 属性
    • row-gap、column-gap、gap 属性
    • grid-template-areas 属性
    • grid-auto-flow 属性
    • justify-items、align-items、place-items 属性
    • justify-content、align-content、place-content 属性
    • grid-auto-columns、grid-auto-rows 属性
  • 项目属性
    • grid-column-start、grid-column-end、grid-row-start、grid-row-end 属性
    • grid-area 属性
    • justify-self、align-self、place-self 属性
  • Grid 实战
    • fr 实现等分响应式
    • repeat + auto-fit——固定列宽,改变列数量
    • repeat+auto-fit+minmax 去掉右侧空白
    • repeat+auto-fit+minmax-span-dense 解决空缺问题
  • 网友评价

Grid布局是一种用于网页布局的CSS技术,它允许开发者定义一个元素内部的行和列,并在这些网格中放置子元素。
这是一个强大的布局方式,可以看作是二维布局,也是唯一的二维布局方案。

容器属性

display 属性

通过在元素上声明 display:grid 或 display:inline-grid 来创建一个网格容器。

  • display:grid :该容器是一个块级元素
  • display: inline-grid :容器元素为行内元素
<div class="wrapper">
    <div class="one item">One</div>
    <div class="two item">Two</div>
    <div class="three item">Three</div>
    <div class="four item">Four</div>
    <div class="five item">Five</div>
    <div class="six item">Six</div>
</div>

<style>
    .wrapper {
        display: grid;
    }
</style>

grid-template-columns 和 grid-template-rows 属性

  • grid-template-columns :设置列宽
  • grid-template-rows :设置行高
.wrapper {
    display: grid;
  	gap: 5px;
    /*  声明了三列,宽度分别为 200px 100px 200px */
    grid-template-columns: 200px 100px 200px;
    /*  声明了两行,行高分别为 50px 50px  */
    grid-template-rows: 50px 50px;
}

在这里插入图片描述

  1. repeat()
    可以简化重复的值。该函数接受两个参数,第一个参数是重复的次数,第二个参数是所要重复的值。
    比如上面行高都是一样的,我们可以这么去实现,实际效果是一模一样的
    .wrapper {
      display: grid;
      gap: 5px;
      grid-template-columns: 200px 100px 200px;
      /*  2行,而且行高都为 50px  */
      grid-template-rows: repeat(2, 50px);
    }
    
    

.

  1. auto-fill
    表示自动填充,多少列(行)自适应,让一行(或者一列)中尽可能的容纳更多的单元格。

    grid-template-columns: repeat(auto-fill, 200px) 表示列宽是 200 px,但列的数量是不固定的,只要浏览器能够容纳得下,就可以放置元素,代码以及效果如下图所示:

    .wrapper-2 {
      display: grid;
      gap: 5px;
      /*  列宽200px  多少列自适应 */
      grid-template-columns: repeat(auto-fill, 200px);
      grid-template-rows: 50px 50px;
    }
    

    在这里插入图片描述
    .

  2. fr
    fr 单位代表网格容器中可用空间的一等份。
    grid-template-columns: 200px 1fr 2fr 表示第一个列宽设置为 200px,后面剩余的宽度分为两部分,宽度分别为剩余宽度的 1/3 和 2/3。代码以及效果如下图所示:

    .wrapper {
      display: grid;
      gap: 5px;
      /*  第一个列宽设置为 200px,后面列宽分别为剩余宽度的 1/3 和 2/3  */
      grid-template-columns: 200px 1fr 2fr;
      grid-template-rows: 50px 50px;
    }
    

    在这里插入图片描述
    .

  3. minmax()
    minmax() 函数产生一个长度范围,表示长度就在这个范围之中都可以应用到网格项目中。

    它接受两个参数,分别为最小值和最大值。

    grid-template-columns: 1fr 1fr minmax(300px, 2fr) 的意思是,第三个列宽最少也是要 300px,但是最大不能大于第一第二列宽的两倍。代码以及效果如下:

    .wrapper {
      display: grid;
      gap: 5px;
      /*  第三个列宽最少也是要 300px,但是最大不能大于第一第二列宽的两倍  */
      grid-template-columns: 1fr 1fr minmax(300px, 2fr);
      grid-template-rows: 50px 50px;
    }
    

    在这里插入图片描述
    .

  4. auto
    通过 auto 关键字,我们可以轻易实现三列或者两列布局。
    grid-template-columns: 100px auto 100px 表示第一第三列为 100px,中间由浏览器决定长度,代码以及效果如下:

    .wrapper {
      display: grid;
      gap: 5px;
      /*  第一第三列为 100px,中间自适应  */
      grid-template-columns: 100px auto 100px;
      grid-template-rows: 50px 50px;
    }
    

    在这里插入图片描述


row-gap、column-gap、gap 属性

  • row-gap:设置行间距
  • column-gap :设置列间距
  • gap:是两者的简写形式

grid-row-gap、grid-column-gap、grid-gap 属性已被废弃,建议使用新的、未被废弃的属性row-gapcolumn-gapgap

这些属性是在CSS Grid规范拟定早期加入的,用于设置网格布局中行与行之间、列与列之间以及行和列之间的间距。然而,随着gap属性在CSS3新特性中的普及,这些旧的grid-*属性被逐渐废弃。

.wrapper {
  display: grid;
  grid-template-columns: 200px 100px 100px;
  grid-template-rows: 50px 50px 50px;
  /*  行间距是10px  */
  row-gap: 10px;
  /*  列间距是20px  */
  column-gap: 20px;
  /* 简写: 行间距是10px  列间距是20px */
  gap: 10px 20px;
}

在这里插入图片描述


grid-template-areas 属性

grid-template-areas 属性用于定义区域,一个区域由一个或者多个单元格组成

一般这个属性跟网格元素的 grid-area 一起使用,我们在这里一起介绍。
grid-area 属性指定项目放在哪一个区域

.wrapper {
  display: grid;
  gap: 10px;
  grid-template-columns: 120px  120px  120px;
  grid-template-areas:
    ". header  header"
    "sidebar content content";
}

.sidebar {
  grid-area: sidebar;
}

.content {
  grid-area: content;
}

.header {
  grid-area: header;
}

上面代码表示划分出 6 个单元格,其中值得注意的是 . 符号代表空的单元格,也就是没有用到该单元格。

header元素会占据第一行的两个连续区域,aside元素会占据第二行的第一个区域,而两个content 元素会占据第二行的后两个区域。
在这里插入图片描述


grid-auto-flow 属性

grid-auto-flow 属性控制着自动布局算法怎样运作,精确指定在网格中被自动布局的元素怎样排列。

  • grid-auto-flow: row:放置顺序是"先行后列",即先填满第一行,再开始放入第二行(默认值是 row)

    .wrapper {
      display: grid;
      gap: 5px;
      grid-template-columns: 100px 200px 100px;
      grid-auto-rows: 50px;
      grid-auto-flow: row;
    }
    

    在这里插入图片描述

  • grid-auto-flow: column:放置顺序是"先列后行",即先填满第一列,再开始放入第二列

    .wrapper {
        display: grid;
        gap: 5px;
        grid-auto-columns: 100px;
        grid-template-rows: 50px 50px;
        grid-auto-flow: column;
    }
    

    在这里插入图片描述


justify-items、align-items、place-items 属性

作用的是每个单元格item

  • justify-items每个单元格的水平位置(左中右)
  • align-items每个单元格的垂直位置(上中下)
  • place-items:是两者的简写形式
.wrapper {
    display: grid;
    gap: 5px;
    grid-template-columns: 100px 200px 100px;
    grid-auto-rows: 50px;
    justify-items: start;
}

它们都有四个值:start | end | center | stretch

  • stretch:拉伸,占满单元格的整个宽度(默认值)

在这里插入图片描述

  • start:对齐单元格的起始边缘
    在这里插入图片描述

  • end:对齐单元格的结束边缘
    在这里插入图片描述

  • center:单元格内部居中
    在这里插入图片描述


justify-content、align-content、place-content 属性

作用的是整个内容区域content

  • justify-content:是整个内容区域在容器里面的水平位置(左中右)
  • align-content:是整个内容区域在容器里面的垂直位置(上中下)
.wrapper {
    display: grid;
    gap: 5px;
    grid-template-columns: 100px 200px 100px;
    grid-auto-rows: 50px;
    justify-content: start;
}

它们都有七个值:start | end | center | stretch | space-around | space-between | space-evenly

  • start:对齐容器的起始边框
  • end:对齐容器的结束边框
  • center:容器内部居中
    在这里插入图片描述

.

  • space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍
  • space-between:项目与项目的间隔相等,项目与容器边框之间没有间隔
  • space-evenly:项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔
  • stretch:项目大小没有指定时,拉伸占据整个网格容器
    在这里插入图片描述

grid-auto-columns、grid-auto-rows 属性

仅影响那些未明确设置大小的列(行)

  • grid-auto-columns:设置网格容器中列的默认大小
  • grid-auto-rows:设置网格容器中行的默认大小

该属性的语法允许使用多种值:

  • auto:默认值,由容器的大小决定列的尺寸
  • max-content:根据列中最大的网格元素设置每列的大小
  • min-content:根据列中最小的网格元素设置每列的大小
  • length:使用自定义的长度值设置列的大小
.wrapper {
    display: grid;
    gap: 10px;
    grid-template-columns: 200px 100px;
    /*  只设置了两行,但实际的数量会超出两行,超出的行高会以 grid-auto-rows 算 */
    grid-template-rows: 100px 100px;
    grid-auto-rows: 50px;
}
  • 显式网格:这里grid-template-columnsgrid-template-rows 属性只是指定了两行两列,也就是4个元素的显式网格。
  • 隐式网格:但实际有九个元素,剩下的4个元素就是隐式网格。通过 grid-auto-rows 可以指定隐式网格的行高为 50px

如下图所示:
在这里插入图片描述

在早期的CSS Grid规范中,当网格容器的内容超出了显式定义的网格线时,会创建隐式网格。

然而,隐式网格的某些行为可能会导致布局的不确定性,因此现在更推荐使用显式定义网格线的方式来避免这些问题。



项目属性

grid-column-start、grid-column-end、grid-row-start、grid-row-end 属性

可以指定网格项目所在的四个边框,分别定位在哪根网格线,从而指定项目的位置

  • grid-column-start:左边框所在的垂直网格线
  • grid-column-end:右边框所在的垂直网格线
  • grid-row-start:上边框所在的水平网格线
  • grid-row-end:下边框所在的水平网格线
.wrapper {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  grid-auto-rows: minmax(100px, auto);
}
.one {
  grid-column-start: 1;
  grid-column-end: 2;
  background: #19CAAD;
}
.two { 
  grid-column-start: 2;
  grid-column-end: 4;
  grid-row-start: 1;
  grid-row-end: 2;
  /*   如果有重叠,就使用 z-index */
  z-index: 1;
  background: #8CC7B5;
}
.three {
  grid-column-start: 3;
  grid-column-end: 4;
  grid-row-start: 1;
  grid-row-end: 4;
  background: #D1BA74;
}
.four {
  grid-column-start: 1;
  grid-column-end: 2;
  grid-row-start: 2;
  grid-row-end: 5;
  background: #BEE7E9;
}
.five {
  grid-column-start: 2;
  grid-column-end: 3;
  grid-row-start: 2;
  grid-row-end: 5;
  background: #E6CEAC;
}
.six {
  grid-column: 3;
  grid-row: 4;
  background: #ECAD9E;
}

上面代码中:.two 所在的网格项目,垂直网格线是从 2 到 4,水平网格线是从 1 到 2。其中它跟 .three (垂直网格线是从3 到 4,水平网格线是从 1 到 4) 是有冲突的。可以设置 z-index 去决定它们的层级关系


grid-area 属性

grid-area 属性指定项目放在哪一个区域,与上面的 grid-template-areas类似

<div class="wrapper">
  <div class="box header">Header</div>
  <div class="box sidebar">Sidebar</div>
  <div class="box content">Content</div>
</div>
.wrapper {
  margin: 50px;
  display: grid;
  gap: 10px;
  grid-template-columns: 120px  120px  120px;
  grid-template-areas:
    ". header  header"
    "sidebar content content";
  background-color: #fff;
  color: #444;
}

.sidebar {
  grid-area: sidebar;
}

.content {
  grid-area: content;
}

.header {
  grid-area: header;
}

在这里插入图片描述


justify-self、align-self、place-self 属性

justify-itemsalign-itemsplace-items属性的用法完全一致,但只作用于单个项目

  • justify-self:设置单元格内容的水平位置(左中右)
  • align-self:设置单元格内容的垂直位置(上中下)
  • place-self:是两者的简写形式

它们有同样的四个值:start | end | center | stretch

.item {
  justify-self: start;
}
.item-1 {
  justify-self: end;
}
.item-2 {
  justify-self: center;
}
.item-3 {
  justify-self: stretch;
}
  • stretch:拉伸,占满单元格的整个宽度(默认值)
    在这里插入图片描述

  • start:对齐单元格的起始边缘
    在这里插入图片描述

  • end:对齐单元格的结束边缘
    在这里插入图片描述

  • center:单元格内部居中
    在这里插入图片描述



Grid 实战

fr 实现等分响应式

fr 等分单位,可以将容器的可用空间分成想要的多个等分空间。利用这个特性,我们能够轻易实现一个等分响应式。

grid-template-columns: 1fr 1fr 1fr 表示容器分为三等分

.wrapper {
  display: grid;
  gap: 10px 20px;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-rows: 50px;
}

在这里插入图片描述

等分布局并不只有 Grid 布局才有,像 flex 布局也能轻松实现:flex: 1


repeat + auto-fit——固定列宽,改变列数量

网格能够固定列宽,并根据容器的宽度来改变列的数量。

这个时候,我们可以用到上面提到 repeat() 函数以及 auto-fit 关键字

grid-template-columns: repeat(auto-fit, 200px) 表示固定列宽为 200px,数量是自适应的,只要容纳得下,就会往上排列,代码以及效果实现如下:

.wrapper {
  display: grid;
  gap: 10px 20px;
  /* 固定列宽为 200px,数量是自适应的 */
  grid-template-columns: repeat(auto-fit, 200px);
  grid-auto-rows: 50px;
}

在这里插入图片描述


repeat+auto-fit+minmax 去掉右侧空白

上面看到的效果中,右侧通常会留下空白,这是我们不希望看到的。如果列的宽度也能在某个范围内自适应就好了。

minmax() 函数就帮助我们做到了这点。

grid-template-columns: repeat(auto-fit, 200px) 改成 grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) 表示每列的数量是自适应的;列宽至少是200px,如果还有空余则一起等分。

.wrapper {
  display: grid;
  gap: 10px 20px;
  /* 每列的数量是自适应的;列宽至少是200px,如果还有空余则一起等分 */
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  grid-auto-rows: 50px;
}

在这里插入图片描述


repeat+auto-fit+minmax-span-dense 解决空缺问题

如果每个网格元素的长度不相同,则通过 span 关键字进行设置网格项目的跨度

grid-column-start: span 3,表示这个网格项目跨度为 3。

.four {
  grid-column-start: span 3;
}

在这里插入图片描述
怎么右侧又有空白了?原来是有一些长度太长了,放不下。

这个时候就到我们的 dense 关键字 出场了。

grid-auto-flow: row dense 表示尽可能填充,而不留空白

.wrapper {
  display: grid;
  gap: 10px 20px;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  grid-auto-rows: 50px;
  grid-auto-flow: row dense;
}

网友评价

  • 张鑫旭:强虽然强,但是学起来累啊,我并不看好日后的普及。

  • 强大并不意味着实用,还是要考虑实际情况

  • Grid兼容性低于flex,不兼容ie


链接:最强大的 CSS 布局 —— Grid 布局 https://juejin.cn/post/6854573220306255880

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/573550.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AI图书推荐:AI驱动的图书写作工作流—从想法构思到变现

《AI驱动的图书写作工作流—从想法到变现》&#xff08;AI-Driven Book Creation: From Concept to Cash&#xff09;是Martynas Zaloga倾力打造的一本实用指南&#xff0c;它巧妙地将写作艺术与人工智能前沿技术相结合。此书不仅揭示了AI在图书出版领域的无限潜力&#xff0c;…

Delphi 的Show和ShowModal

Show没有返回值是一个过程&#xff0c;焦点可以不在当前窗体&#xff1b; 用法新建一个子窗体&#xff1a; 主窗体&#xff1a; 调用&#xff0c;引用子窗体的单元 调用 showmodal是一个函数有返回值&#xff0c;窗体的处理结果&#xff0c;且只能聚焦到当前窗体 效果都能展示…

echarts实现云台控制按钮效果,方向按钮

效果图 代码 option {color: [#bfbfbf],tooltip: {show: false},series: [{name: ,type: pie,radius: [40%, 70%],avoidLabelOverlap: true,itemStyle: {// borderRadius: 10,borderColor: #fff,borderWidth: 2},label: {show: true,position: inside,fontSize: 36,color: #f…

CST初级教程 二

本教程将讲解CST Studio的视窗操控的基本操作. 3D视窗的快捷操作 动态放大与缩小&#xff08;Dynamic Zoom&#xff09; 将鼠标指针移动到CST Studio图形视窗中&#xff0c;向上滚动鼠标滚轮&#xff0c;可动太放大图形视窗中的显示内容&#xff0c;向下滚动鼠标滚轮即可动态缩…

如何添加所有未跟踪文件到暂存区?

文章目录 如何将所有未跟踪文件添加到Git暂存区&#xff1f;步骤与示例代码1. 打开命令行或终端2. 列出所有未跟踪的文件3. 添加所有未跟踪文件到暂存区4. 验证暂存区状态 如何将所有未跟踪文件添加到Git暂存区&#xff1f; 在版本控制系统Git中&#xff0c;当我们首次创建新文…

《数据结构与算法之美》读书笔记4(递归)

递归是一种应用非常广泛的算法。之后要讲的很多数据结构和算法的编码实现都要用到递归&#xff1a;DFS深度优先搜索&#xff0c;前中后序二叉树遍历等。 推荐注册返佣金这个功能&#xff0c;用户A推荐用户B来注册&#xff0c;用户B推荐用户C来注册。可以说用户B的“最终推荐人…

乐鑫科技收购创新硬件公司 M5Stack 控股权

乐鑫科技 (688018.SH) 宣布收购 M5Stack&#xff08;明栈信息科技&#xff09;的控股权。这一战略举措对于物联网和嵌入式系统领域的两家公司来说都是一个重要的里程碑&#xff0c;也契合了乐鑫和 M5Stack 共同推动 AIoT 技术民主化的愿景。 M5Stack 以其创新的硬件开发方式而闻…

DSP技术及应用——学习笔记一(量化效应)

文章图片内容主要来着老师的PPT&#xff0c;内容为自己总结梳理的学习笔记 二进制定点表示与量化误差 二进制定点表示 基础知识 二进制小数的定点表示 正数小数的定点表示&#xff1a; 思考题&#xff1a;推算字长为16的二进制最大正数与二进制正数 补码&#xff1a;正数不变&…

微电子封装分类及引线键合

1微电子封装分类 - 按功能 模拟电路、存储器传感器、功率电路、光电器件、逻辑电路、射频电路、MEMS、LED等等 - 按结构 分立器件/单芯片封装、多芯片封装、三维封装、真空封装、非真空封装、CSP,BGA/FBGA等等 - 按工艺 线焊封装(WB)、倒装焊封装(FC)、晶圆级封装(WLP)等等 -…

华中农业大学第十三届程序设计竞赛 个人题解(待补)

前言&#xff1a; 注意本篇博客的题解目前并不完整&#xff0c;未来会慢慢补齐的。 进入实验室后接触算法比赛的机会更多了&#xff0c;我接触的题也不再是简单的c语言题了&#xff0c;开始遇到更多我没接触过的算法和难题了&#xff0c;死磕这些难题对现在的我不但花时间而且成…

kubebuilder(4)部署测试

将crd部署到k8s make install 日志&#xff1a; kustomize build config/crd | kubectl apply -f - customresourcedefinition.apiextensions.k8s.io/demoes.tutorial.demo.com created 查看下[rootpaas-m-k8s-master-1 demo-operator]# kubectl api-resources | grep demo de…

python爬虫学习-------scrapy的第一部分(二十九天)

&#x1f388;&#x1f388;作者主页&#xff1a; 喔的嘛呀&#x1f388;&#x1f388; &#x1f388;&#x1f388;所属专栏&#xff1a;python爬虫学习&#x1f388;&#x1f388; ✨✨谢谢大家捧场&#xff0c;祝屏幕前的小伙伴们每天都有好运相伴左右&#xff0c;一定要天天…

【stomp实战】搭建一套websocket推送平台

前面几个小节我们已经学习了stomp协议&#xff0c;了解了stomp客户端的用法&#xff0c;并且搭建了一个小的后台demo&#xff0c;前端页面通过html页面与后端服务建立WebSocket连接。发送消息给后端服务。后端服务将消息内容原样送回。通过这个demo我们学习了前端stomp客户端的…

BBEdit for Mac v15.0.3激活版 支持多种类型的代码编辑器

BBEdit包含了很多一流的功能&#xff0c;包括GREP图样匹配&#xff0c;搜索和替换多个文件&#xff08;即使未开启的远程服务器上的文件&#xff09;&#xff0c;项目定义的工具&#xff0c;功能导航和众多的源代码语言的语法着色&#xff0c;代码折叠&#xff0c;FTP和SFTP打开…

视频质量度量VQM算法详细介绍

视频质量评价 视频质量评价(Video Quality Assessment,VQA)是指通过主观、客观的方式对视频图像的内容、画质等,进行感知、衡量与评价。 ITU definations subjective assessment: the determination of the quality or impairment of programme-like pictures presented…

后端程序员利用 AI 给网站制作专业 favicon

看看你的 Chrome 浏览器顶部的标签页&#xff0c;每个标签页前面有一个小小的图标&#xff0c;这个就是 favicon&#xff0c;如果你将网页保存到收藏夹&#xff0c;前面也会是这个小图标。这个图标有时候就是网站的 Logo&#xff0c;有时候也不太一样。 上面截图中&#xff0c…

C++学习随笔(10)——string

本章我们来了解一下string类。 目录 1. string类是什么&#xff1f; 1.1 C语言中的字符串 1.2 string类本质 2. 标准库中的string类 2.1 string类 2.2 string类的常用接口说明 1. string类对象的常见构造 2. string类对象的容量操作 3. string类对象的访问及遍历操作…

static和extern关键字详解

目录 创作不易&#xff0c;如对您有帮助&#xff0c;还望一键三连&#xff0c;谢谢&#xff01;&#xff01;&#xff01; 回顾 1.作用域和声明周期 1.1作用域 1.2生命周期 2.static和extern 2.1extern 2.2static 2.2-1static修饰局部变量 2.2-2static修饰全局变量 创…

vue flvjs 播放视频

写在前面&#xff1a; 之前使用过vodiejs插件播放过mp4视频格式的视频&#xff1b; 此次需要使用flvjs插件播放rtsp视频格式的视频&#xff1b; 因为视频的数据格式不同&#xff0c;所以对应的插件不同。 思维导图&#xff1a; 参考链接&#xff1a;rtmp、rtsp、flv、m3u8、 …

手把手教会你做属于自己的网站《保姆级教程》

手把手教会你做属于自己的网站《保姆级教程》 前言开始教程特别说明下期内容预报 前言 什么是个人网站&#xff1f; 个人网站是指因特网上一块固定的面向全世界发布消息的地方&#xff0c;通常由域名&#xff08;也就是网站地址&#xff09;、程序和网站空间构成&#xff0c;并…