前端必备——Grid布局详解

article/2025/8/23 16:05:20

在这里插入图片描述

Grid布局,又称为CSS网格布局,是W3C提出的一个二维布局系统,它允许开发者以行和列的形式来布局网页内容。以下是Grid布局属性的详细解析:

一、容器属性

  1. display

    • grid:将元素设置为块级网格容器。
    • inline-grid:将元素设置为行内网格容器。
  2. 定义网格轨道(行和列)

    • grid-template-columns:定义网格的列数及其大小。可以使用长度单位(如px、em等)、百分比(%)或fr单位(表示剩余空间的比例分配)。
    • grid-template-rows:定义网格的行数及其大小。与grid-template-columns类似,也可以使用长度单位、百分比或fr单位。

    示例

    .grid-container {display: grid;grid-template-columns: 100px 1fr 2fr;grid-template-rows: repeat(3, 100px);
    }
    

    上述代码创建了一个具有三列和三行的网格,其中第一列宽度为100px,第二列占据剩余空间的1/3,第三列占据剩余空间的2/3;所有行的高度均为100px。

  3. repeat()函数

    • 用于简化重复的网格轨道定义。
    • 语法:repeat(次数, 值)

    示例

    .grid-container {grid-template-columns: repeat(3, 1fr);
    }
    

    上述代码表示创建三列,每列的宽度相等,均占据剩余空间的1/3。

  4. auto-fill/auto-fit关键字

    • 与repeat()函数结合使用,根据容器大小自动填充网格轨道。
    • auto-fill:尽可能多地填充网格轨道,直到无法再添加更多轨道为止。
    • auto-fit:与auto-fill类似,但会尝试调整轨道大小以适应容器。
  5. minmax()函数

    • 定义一个长度范围作为网格轨道的最小和最大尺寸。
    • 语法:minmax(最小值, 最大值)

    示例

    .grid-container {grid-template-columns: 1fr minmax(100px, 1fr) 2fr;
    }
    

    上述代码表示第一列和第三列的宽度分别为1fr和2fr,第二列的宽度不小于100px且不大于1fr。

  6. grid-gap/gap

    • 设置网格行和列之间的间距。
    • gap是grid-gap的简写形式。
    • 可以接受两个值:第一个值表示行间距,第二个值表示列间距(如果仅提供一个值,则行间距和列间距相同)。

    示例

    .grid-container {gap: 10px 20px;
    }
    

    上述代码表示行间距为10px,列间距为20px。

  7. grid-template-areas

    • 通过命名网格区域来布局网格项目。
    • 需要在子元素上使用grid-area属性指定其所属区域。

    示例

    .grid-container {display: grid;grid-template-columns: repeat(3, 100px);grid-template-rows: repeat(3, 100px);grid-template-areas:'a a a''b c d''e e f';
    }
    .item1 { grid-area: a; }
    .item2 { grid-area: b; }
    /* 以此类推 */
    
  8. grid-auto-flow

    • 设置容器子元素的放置在网格中的顺序。
    • 可选值:row(默认,按行填充)、column(按列填充)、row dense(尽可能紧密地按行填充,避免空白)、column dense(尽可能紧密地按列填充,避免空白)。
  9. justify-items/align-items

    • 设置网格项目在单元格内的水平和垂直对齐方式。
    • 可选值:start、end、center、stretch(默认,拉伸以占满单元格)。
  10. justify-content/align-content

    • 设置网格项目在容器内的水平和垂直对齐方式(针对整行或整列)。
    • 可选值与justify-items/align-items相同。

二、项目属性

  1. grid-column-start/grid-column-end

    • 定义元素在网格中的起始和结束列位置。
    • 可以使用网格线的编号或名称。
  2. grid-row-start/grid-row-end

    • 定义元素在网格中的起始和结束行位置。
    • 使用方式与grid-column-start/grid-column-end相同。
  3. grid-column/grid-row

    • grid-column-start和grid-column-end或grid-row-start和grid-row-end的简写。
    • 用于指定网格项目的位置和跨度。
  4. grid-area

    • 一种简写属性,用于同时设置元素的grid-row-start、grid-column-start、grid-row-end及grid-column-end。
    • 也可以使用网格区域的名称来指定位置。
  5. justify-self/align-self

    • 设置单个网格项目在其单元格内的水平和垂直对齐方式。
    • 可以覆盖容器的justify-items和align-items属性。
  6. place-self

    • justify-self和align-self的合并简写形式。

Grid布局以其强大的二维布局能力和灵活性成为现代网页设计中不可或缺的一部分。通过合理使用这些属性和方法,开发者可以创建出各种复杂且响应式的网页布局。

Grid布局,即网格布局,是一个二维的布局方式,由纵横相交的两组网格线形成的框架性布局结构,能够同时处理行与列,擅长将一个页面划分为几个主要区域,并定义这些区域的大小、位置、层次等关系。以下是一些常见的Grid布局形式,同时也是面试中常考的内容:

一、基础网格布局

这是Grid布局最基本的形式,通过定义grid-template-columnsgrid-template-rows属性来设置网格的行和列。例如:

.container {display: grid;grid-template-columns: 100px 1fr 100px;grid-template-rows: 50px auto 50px;
}

在这个例子中,容器被划分为三列和三行,其中第一列和第三列的宽度为100px,第二列的宽度自适应;第一行和第三行的高度为50px,第二行的高度自适应。

二、命名网格区域布局

使用grid-template-areas属性可以为网格定义命名区域,这样可以通过名称而不是行和列的数字来放置Grid项。例如:

.container {display: grid;grid-template-columns: 100px 100px 100px;grid-template-rows: 100px 100px 100px;grid-template-areas:'header header header''main aside aside''footer footer footer';
}.header {grid-area: header;
}.main {grid-area: main;
}.aside {grid-area: aside;
}.footer {grid-area: footer;
}

在这个例子中,容器被划分为9个单元格,并通过grid-template-areas属性命名为headermainasidefooter四个区域。然后,通过grid-area属性将具体的元素放置到这些命名区域中。

三、隐式网格布局

隐式网格是没有使用属性定义的,通过使用自动布局创建出来的网格。当容器中的项目数量超过显式定义的网格区域时,浏览器会自动创建隐式网格来容纳这些项目。例如:

.container {display: grid;grid-template-columns: 100px 1fr;grid-auto-rows: 50px; /* 定义隐式网格的行高 */
}.item {/* 项目样式 */
}

在这个例子中,只显式定义了两列,但如果有更多的项目,浏览器会自动创建隐式网格行来容纳这些项目,每行的高度为50px。

四、使用fr单位进行比例布局

fr单位允许将轨道大小设置为网格容器自由空间的一部分。例如:

.container {display: grid;grid-template-columns: 1fr 2fr 1fr;
}

在这个例子中,容器被划分为三列,每列的宽度占容器总宽度的1/4、1/2和1/4。

五、使用span关键字进行跨行/跨列布局

使用span关键字可以设置特定元素将跨越的列数或行数。例如:

.item1 {grid-column: span 2; /* 跨越两列 */
}.item2 {grid-row: span 2; /* 跨越两行 */
}

在这个例子中,item1将跨越两列,而item2将跨越两行。

六、使用justify-itemsalign-itemsjustify-contentalign-content进行对齐布局

这些属性用于控制网格项在网格容器中的对齐方式。例如:

.container {display: grid;grid-template-columns: 100px 100px;grid-template-rows: 100px 100px;justify-items: center; /* 水平方向居中对齐 */align-items: center; /* 垂直方向居中对齐 */justify-content: space-between; /* 水平方向两端对齐,中间间隔均匀 */align-content: space-around; /* 垂直方向间隔均匀分布 */
}

在这个例子中,网格项在水平和垂直方向上都居中对齐,同时容器内的网格项在水平和垂直方向上的间隔也进行了相应的设置。

综上所述,Grid布局提供了多种布局形式,能够满足复杂的网页布局需求。在面试中,了解并掌握这些常见的Grid布局形式是非常重要的。


http://www.hkcw.cn/article/NVDQspZIVl.shtml

相关文章

基于Java Web和SSM框架的硕士研究生招生考试系统开发

本文还有配套的精品资源,点击获取 简介:本项目旨在构建一个硕士研究生招生考试专业报考查询及学习系统,使用Java Web技术并集成了Spring、SpringMVC和MyBatis(SSM)框架。系统通过模块化架构和分离关注点&#xff08…

MCP Web Research Server 安装与配置指南

MCP Web Research Server 安装与配置指南 mcp-webresearch MCP web research server (give Claude real-time info from the web) 项目地址: https://gitcode.com/gh_mirrors/mcpw/mcp-webresearch 1. 项目基础介绍 MCP Web Research Server 是一个基于 Model Context …

0基础入门前端到精通(一)

目录 一丶前端开发介绍 1. 网页的组成部分 2. 网页的本质是什么? 3. 前端代码如何变成网页? 4. 统一网页显示标准:Web 标准 二丶HTML & CSS 1. 什么是 HTML? 2. 什么是 CSS? ​3. HTML 快速入门&#xff0…

一文了解Blob文件格式,前端必备技能之一

文章目录 前言一、什么是Blob?二、Blob的基本特性三、Blob的构造函数四、常见使用场景1. 文件下载2. 图片预览3. 大文件分片上传 四、Blob与其他API的关系1. File API2. FileReader3. URL.createObjectURL()4. Response 五、性能与内存管理六、实际案例:…

双剑破天门:攻防世界Web题解之独孤九剑心法(十)

免责声明:用户因使用公众号内容而产生的任何行为和后果,由用户自行承担责任。本公众号不承担因用户误解、不当使用等导致的法律责任 **本文以攻防世界部分题为例进行演示,后续会对攻防世界大部分的web题目进行演示,如果你感兴趣请…

解决 Android WebView 无法加载 H5 页面常见问题的实用指南

目录 1. WebView 简介 2. 常见问题 3. 网络权限设置 4. 启用 JavaScript 5. DOM Storage 的重要性 6. 处理 HTTPS 问题 7. 设置 WebViewClient 8. 调试工具 9. 其他调试技巧 10. 结论 相关推荐 1. WebView 简介 Android WebView 是一种视图组件,使得 And…

【若依框架】代码生成详细教程,15分钟搭建Springboot+Vue3前后端分离项目,基于Mysql8数据库和Redis5,管理后台前端基于Vue3和Element Plus,开发小程序数据后台

今天我们来借助若依来快速的搭建一个基于springboot的Java管理后台,后台网页使用vue3和 Element Plus来快速搭建。这里我们可以借助若依自动生成Java和vue3代码,这就是若依的强大之处,即便你不会Java和vue开发,只要跟着石头哥也可以快速的开发一款Java和vue程序。 技术点 …

OpenWebUI如何对外提供HTTP接口?

from 公众号:程序员more OpenWebUI通过HTTP方式提供对外接口,使得开发者可以通过HTTP方式快速对接拥有RAG能力的模型基座。 01 OpenWebUI配置app key OpenWebUI使用BearerToken机制对 API 请求进行身份验证。从 Open WebUI 中的“设置>帐户”获取 …

中使馆回应美将撤销中国留学生签证 坚决反对歧视做法

中使馆回应美将撤销中国留学生签证 坚决反对歧视做法!中国驻美国大使馆发言人于5月29日针对美国务院发表的声明作出回应,该声明称将撤销有关中国在美留学生的签证。发言人表示,中方坚决反对美方这一政治性、歧视性的做法。这种行为将严重损害中国在美留学人员的正当合法权益…

【Markdown基础语法】

Markdown语法 顶部 一、标题#~###### 一级标题 二级标题 三级标题 四级标题 五级标题 六级标题 二、粗体 **粗体** 粗体字 三、斜体** 斜体字 四、删除字~~~~ 删除文字​ 五、分割线***、—、___ 六、无序列表-、、* 1 2 3 七、有序列表数字后加点1. 第一项第二项 …

ROS云课基础篇-03-apt趣味小应用-250529

基本看完01和02,还想继续,十分魔幻,来点有趣好玩的吧。 ROS云课基础篇-01-Linux-250529-CSDN博客 ROS云课基础篇-02-C-250529-CSDN博客 在Ubuntu中,有许多有趣且实用的小应用可以为系统增添乐趣和功能性。以下是一些类似xeyes和…

上海老电梯更新费用规定 公积金可提取支付

上海老电梯更新费用规定 公积金可提取支付。为支持职工筹集住宅老旧电梯更新费用,改善居住条件,上海市住房公积金管委会近日印发《关于上海市住房公积金支持老旧电梯更新有关政策的通知》,将于2025年7月1日起施行。根据通知规定,住宅老旧电梯更新项目经业主依法表决通过,小…

网络编程之网络编程预备知识

网络编程预备知识 1. 网络编程 1.1 网络通信 通信/通讯需要具备两个基本条件: 物理媒介(物理层面) 网线,光纤 协议(软件层面)网络通信协议 1.2 网络协议层次模型 层次:把不同的功能封装成…

Spring Boot+Activiti7入坑指南初阶版

介绍  Activiti 是一个轻量级工作流程和业务流程管理 (BPM) 平台,面向业务人员、开发人员和系统管理员。其核心是一个超快且坚如磐石的 Java BPMN 2 流程引擎。它是开源的,并根据 Apache 许可证分发。Activiti 可以在任何 Java 应用程序、服务器、集群或云中运行。它与 Spri…

信创改造选择C86,相比于ARM架构有什么优势?

随着信息技术应用创新(信创)产业的快速发展,信创改造已成为我国信息技术产业升级的重要方向。信创改造的核心目标是实现信息技术的自主可控,保障国家信息安全,同时推动国产软硬件在各行业的广泛应用。 2025年作为信创产…

20250529-C#知识:运算符重载

C#知识:运算符重载 运算符重载能够让我们像值类型数据那样使用运算符对类或结构体进行运算,并且能够自定义运算逻辑。 1、运算符重载及完整代码示例 作用是让自定义的类或者结构体能够使用运算符运算符重载一定是public static的可以把运算符看成一个函…

【AI面试秘籍】| 第24期:Transformers / LLM的词表应该选多大?

在构建和训练Transformers以及大型语言模型 (LLM) 时,词表 (Vocabulary) 大小的选择是一个至关重要且常常令人困惑的问题。它不仅直接影响模型的性能,还关系到模型的计算效率和内存占用。那么,当面试官抛出这个问题时,我们应该如何…

一文清晰理解目标检测指标计算

一、核心概念 1.交并比IoU 预测边界框与真实边界框区域的重叠比,取值范围为[0,1] 设预测边界框为,真实边界框为 公式: IoU计算为两个边界框交集面积与并集面积之比,图示如下 IoU值越高,表示预测边界框与真实边界框的对…

一文讲懂fork函数(c语言linux)

c语言的fork函数是拿来创建子进程的, 进程 pcb(process control block) 代码和数据 子进程中的代码和数据与父进程的一致(共享父进程的代码和数据),没有自己的代码和数据. 如果父进程或者子进程要修改数据,操作系统就会把要修改的数据拷贝一份新的,让目标进程修改这份拷贝…

LVDS系列14:Xilinx Ultrascale系可编程输入延迟(四)

本节讲解Ultrascale IDELAYE3的TIME模式仿真;  TIME模式下参数和时序: 必须例化IDELAYCTRL,IDELAYCTRL时钟频率与REFCLK_FREQUEMCY参数相同; 有温度电压补偿,EN_VTC在修改抽头值时拉低,修改完毕后拉高&a…