【CSS Grid网格布局】常用属性,示例代码解读

news2024/9/20 18:39:10

Grid布局是一种二维布局系统,可以将页面划分为行和列,并将元素放置在这些行和列的交叉点上。以下是Grid布局的一些常用属性:

grid-template-columns/grid-template-rows:用于定义网格的列和行的大小和数量。可以指定具体的尺寸值(如px、em等),也可以使用fr单位表示剩余空间的比例分配。

.container {
  display: grid;
  grid-template-columns: 100px 200px 300px;//第一列100px,第二列200px,第三列300px
  grid-template-rows: 50px 100px;//第一行高50px,第二行高100px
}

grid-column-gap/grid-row-gap:用于定义网格的列间距和行间距。可以使用具体的尺寸值或百分比。

grid-gap:grid-row-gap 和 grid-column-gap 的简写属性
语法:
grid-gap: grid-row-gap grid-column-gap;
.container {
  display: grid;
  grid-gap: 10px;//网格元素间距为10px
}

grid-template-areas:用于定义网格区域的布局。通过给每个网格区域命名,然后使用这些名称来指定元素在网格中的位置。

grid-auto-columns/grid-auto-rows:用于定义没有显式指定大小的网格的列和行的大小。可以使用具体的尺寸值或百分比。

grid-auto-flow:用于定义未显式放置在网格中的元素的放置方式。可以设置为"row"、“column"或"dense”。

justify-items/align-items:用于定义网格中所有元素的水平对齐方式和垂直对齐方式。

.item {
  justify-items: center; /* 水平居中对齐 */
  align-items: end; /* 底部对齐 */
}

justify-self/align-self:用于定义单个网格元素的水平对齐方式和垂直对齐方式,会覆盖父级的对齐方式。

grid-column-start/grid-column-end/grid-row-start/grid-row-end:用于定义单个网格元素的起始位置和结束位置。可以使用具体的网格线编号、span关键字或auto值。

grid-column: grid-column-start 和 grid-column-end 的简写属性
语法:
grid-column: grid-column-start / grid-column-end;
grid-row:grid-row-start 和 grid-row-end 的简写属性
语法:
grid-row:grid-row-start / grid-row-end ;
.item {
  grid-column: 2 / 4; /* 从第2列到第4列 */
  grid-row: 1 / 3; /* 从第1行到第3行 */
}

justify-content 和 align-content:设置网格容器中的内容在容器中的对齐方式。

.container {
  display: grid;
  justify-content: center; /* 水平居中对齐 */
  align-content: end; /* 底部对齐 */
}

这些属性可以通过在父元素上设置display属性为grid或inline-grid来启用Grid布局。通过调整这些属性的值,可以实现灵活的网格布局效果。

适用场景:

复杂的布局:CSS Grid布局非常适合创建复杂的网格布局,例如新闻网站的首页或仪表板。
响应式设计:由于CSS Grid布局的灵活性,它非常适合用于响应式设计,以适应不同的屏幕尺寸和设备。
网格嵌套:如果您需要在网格单元格中创建更复杂的嵌套结构,CSS Grid布局是一个很好的选择。
对齐和排序:如果您需要对网格中的元素进行精确的对齐和排序,CSS Grid布局提供了强大的功能。

示例:
在这里插入图片描述

.left-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr); //宽度平均分成两等份
  grid-column-rows: repeat(2, 1fr); //高度平均分成两等份
  grid-template-areas: 'a b' 'a b'; //将现有的四个单元格定义为第一行a b ,第二行a b
  justify-content: center;
  align-items: center;
  margin-top: 10px;
}
.left-list-img {
  grid-area: a; //对应a区域
  width: 50px;
  height: 50px;
  border-radius: 5px;
}
.left-list-title {
  grid-area: b; //对应b区域
}


CSS Grid文档戳这里

文档上示例解读:
在这里插入图片描述
首先了解一些基础知识,帮助我们更好的理解
CSS 网格布局,可在线尝试

网格列:网格元素的垂直线方向称为列(Column)
在这里插入图片描述
网格行:网格元素的水平线方向称为行(Row)
在这里插入图片描述
网格间距(Column Gap)指的是两个网格单元之间的网格横向间距或网格纵向间距。
在这里插入图片描述
最重要的是网格线:
列与列,行与行之间的交接处就是网格线。

Grid 会为我们创建编号的网格线来让我们来定位每一个网格元素。

例如下面这个三列两行的网格中,就拥有四条纵向的网格线(灰色圆圈标记),以及三条横向的网格线(黑色圆圈标记)
在这里插入图片描述
看懂上面这张图后,其实网格线column列就是从纵向的第一根开始,1-4,纵向有四根网格线
row行就是从横向的第一根开始,1-3,横向有三根网格线
下图则定义了四条纵向的网格线,以及四条横向的网格线:
在这里插入图片描述
grid-column是grid-column-start 和 grid-column-end 的简写属性,如果只有一个值代表独占一列,如果两个值代表开始位置与结束位置
在这里插入图片描述
grid-row是grid-row-start 和 grid-row-end 的简写属性,如果只有一个值代表独占一行,如果两个值代表开始位置与结束位置
在这里插入图片描述

<div class="wrapper">
  <div class="one">One</div>
  <div class="two">Two</div>
  <div class="three">Three</div>
  <div class="four">Four</div>
  <div class="five">Five</div>
  <div class="six">Six</div>
</div>
.wrapper {
  display: grid;//开启grid布局
  grid-template-columns: repeat(3, 1fr);//等宽分为3等份
  gap: 10px;//网格单元格之间的间距为10px
  grid-auto-rows: minmax(100px, auto);//网格自动调整行高,最小高度100px,最大高度自动调整
}
.one {
  grid-column: 1 / 3;//纵向第一根网格线到第三根网格线,即第一到第二列
  grid-row: 1;//横向独占第一行
}
.two {
  grid-column: 2 / 4;//纵向第二根网格线到第四根网格线,即第二到第三列,因为都有第二列,所以第二列重合了
  grid-row: 1 / 3;//横向第一根网格线到第三根网格线,即第一到第二行
}
.three {
  grid-column: 1;//纵向独占第一列
  grid-row: 2 / 5;//横向第二根网格线到第五根网格线,即第二到第四行
}
.four {
  grid-column: 3;//纵向独占第三列
  grid-row: 3;//横向独占第三行
}
.five {
  grid-column: 2;//纵向独占第二列
  grid-row: 4;//横向独占第四行
}
.six {
  grid-column: 3;//纵向独占第三列
  grid-row: 4;//横向独占第四行
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【ARM】Day6 cotex-A7核UART总线实验

cotex-A7核UART总线实验 1. 键盘输入一个字符‘a’&#xff0c;串口工具显示‘b’ 2. 键盘输入一个字符串"nihao"&#xff0c;串口工具显示“nihao” uart.h #ifndef __UART4_H__ #define __UART4_H__#include "stm32mp1xx_rcc.h" #include "stm3…

安卓系列机型-禁止安装某软件 防止“沉迷游戏的小孩”操作解析

如何禁止安装某软件。这里以好课帮app为例做个演示步骤说明。这个博文的目的在于可以阻止他人用手机安装你指定的一些软件。 &#x1f494;&#x1f494;&#x1f494;首先手机上安装好课帮这个软件。打开应用详情找到包名。或者使用第三方工具打开获取这个软件的包名。记住是…

Unity 物体固定屏幕尺寸(透视模式)

物体固定屏幕尺寸 &#x1f96a;效果图&#x1f371;食用方法 &#x1f96a;效果图 如图所示物体远离摄像机后会被放大&#xff0c;靠近相机会被缩小&#xff0c;使得在屏幕上的大小保持不变&#xff1b; &#x1f371;食用方法 导入插件后使用gameObject.SetFixedScreenSi…

c#中lambda表达式缩写推演

Del<string> ml new Del<string>(Notify);//泛型委托的实例化&#xff0c;并关联Nofity方法 Del<string> ml new Del<string>(delegate (string str) { return str.Length; });//将Nofity变更为匿名函数 Del<string> ml delegate(string str)…

15.树与二叉树基础

目录 一. 树&#xff0c;基本术语 二. 二叉树 &#xff08;1&#xff09;二叉树 &#xff08;2&#xff09;满二叉树 &#xff08;3&#xff09;完全二叉树 三. 二叉树的性质 四. 二叉树的存储结构 &#xff08;1&#xff09;顺序存储结构 &#xff08;2&#xff09;链…

港联证券|燃气板块午后走高,美能能源涨停,水发燃气大幅拉升

燃气板块21日午后快速拉升&#xff0c;到发稿&#xff0c;美能动力涨停&#xff0c;水发燃气涨超7%&#xff0c;蓝天燃气涨超5%&#xff0c;贵州燃气涨逾4%。 消息面上&#xff0c;受澳大利亚LNG工厂罢工忧虑影响&#xff0c;欧洲基准天然气价格一度大涨18%。 有报导称&#x…

音视频技术开发周刊 | 307

每周一期&#xff0c;纵览音视频技术领域的干货。 新闻投稿&#xff1a;contributelivevideostack.com。 “视象新生”火山引擎视频云&AIGC技术大会邀你踏入新“视界” 8月22日&#xff0c;火山引擎视频云&AIGC技术大会即将开启&#xff01;本次大会以“视象新生”为主…

lvs-dr模式+keepalived

一&#xff0c;keepalived概述 Keepalived 是一个基于VRRP协议来实现的LVS服务高可用方案&#xff0c;可以解决静态路由出现的单点故障问题。 在一个LVS服务集群中通常有主服务器&#xff08;MASTER&#xff09;和备份服务器&#xff08;BACKUP&#xff09;两种角色的服务器&am…

如何创建和销售在线健身业务

快速轻松地创建您自己的线上健身网站&#xff01; 越来越多的人在家健身&#xff0c;在线健身业务也随之快速增长。 虽然这个生意很红火&#xff0c;但是真的像看起来那么容易上手吗&#xff1f; 有了MemberPress&#xff0c;确实如此&#xff01; 在这篇文章中&#xff0c…

【李宏毅机器学习】注意力机制

输出 我们会遇到不同的任务&#xff0c;针对输出的不一样&#xff0c;我们对任务进行划分 给多少输出多少 给一堆向量&#xff0c;输出一个label&#xff0c;比如说情感分析 还有一种任务是由机器决定的要输出多少个label&#xff0c;seq2seq的任务就是这种&#xff0c;翻译也…

Vue.js知识点学习的一点笔记

一、虚拟DOM 1、原生JS是命令式编程&#xff0c;当渲染在页面的数据发生一点点变化&#xff0c;需要整个重新渲染一编。vue.js渐进式框架有个虚拟DOM的概念&#xff0c;运用diff算法&#xff0c;比较新旧数据&#xff0c;相同的数据不变不重渲染&#xff0c;不同的部分新数据…

CAD VCL Multiplatform Crack

CAD VCL Multiplatform Crack CAD VCL多平台是在Delphi和CBuilder中开发应用程序的一个组件。它允许创建、可视化、导入、导出、转换和打印图形。开发人员可以访问实体的属性。CAD VCL多平台支持大量矢量和3D格式&#xff0c;包括AutoCAD DWG/DXF、HPGL、STEP、IGES、STL、SVG、…

Excel带数值的计算公式

问题描述 如图&#xff0c;想实现在第三列单元格中实现带数值的计算表达式 解决方法 单元格 & "/" & 单元格 & "" & TEXT(单元格/单元格, "0.00%")& 为简单的 与 符号 最后设定单元格数值与格式&#xff08;保留两位小数…

[Mac软件]AutoCAD 2024 for Mac(cad2024) v2024.3.61.182中文版支持M1/M2/intel

下载地址&#xff1a;前往黑果魏叔官网 AutoCAD是一款计算机辅助设计&#xff08;CAD&#xff09;软件&#xff0c;目前已经成为全球最受欢迎的CAD软件之一。它可以在二维和三维空间中创建精确的技术绘图&#xff0c;并且可以应用于各种行业&#xff0c;如建筑、土木工程、机械…

天锐绿盾安全U盘系统

安全U盘系统 01 简介 天锐绿盾安全U盘系统&#xff0c;是一款致力于保障U盘数据内容安全的产品。通过严格身份认证、便捷安全的密保机制、智能的U盘锁定或自毁设置、详细的文件操作日志、文件粉碎、设置还原等&#xff0c;天锐绿盾安全U盘系统为您U盘的数据保驾护航&#xff0…

2023年京东儿童智能手表行业数据分析(京东销售数据分析)

儿童消费市场向来火爆&#xff0c;儿童智能手表作为能够实现定位导航&#xff0c;信息通讯&#xff0c;SOS求救&#xff0c;远程监听&#xff0c;智能防丢等多功能的智能可穿戴设备&#xff0c;能够通过较为精准的定位功能和安全防护能力保障儿童的安全&#xff0c;因而广受消费…

子集-回溯方法

class Solution {//题解思路//LinkedList<Integer> path new LinkedList<>(); List<List<Integer>> results new ArrayList<>();public List<List<Integer>> subsets(int[] nums) {//主方法中调用方法同时传入指定的参数初始值bac…

酷开科技大屏营销,锁定目标人群助力营销投放

近日&#xff0c;中科网联发布《2023年中国家庭大屏白皮书》&#xff0c;数据显示智能电视近三年内使用人群增长平稳。全国4.94亿家庭户中&#xff0c;智能大屏渗透率近九成。不仅如此&#xff0c; CCData研究预测&#xff0c;2025年中国智能电视渗透率将达到95%以上。这与三年…

Flink、Yarn架构,以Flink on Yarn部署原理详解

Flink、Yarn架构&#xff0c;以Flink on Yarn部署原理详解 Flink 架构概览 Apache Flink是一个开源的分布式流处理框架&#xff0c;它可以处理实时数据流和批处理数据。Flink的架构原理是其实现的基础&#xff0c;架构原理可以分为以下四个部分&#xff1a;JobManager、TaskM…

华为云Stack的学习(一)

一、华为云Stack架构 1.HCS 物理分散、逻辑统一、业务驱动、运管协同、业务感知 2.华为云Stack的特点 可靠性 包括整体可靠性、数据可靠性和单一设备可靠性。通过云平台的分布式架构&#xff0c;从整体系统上提高可靠性&#xff0c;降低系统对单设备可靠性的要求。 可用性…