news 2026/4/15 18:59:56

grid 布局

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
grid 布局

grid布局含义:

grid布局,也被称之为网格布局,是将页面中的父元素划分成一个个小的格子,然后通过这些小的格子进行合并来制作出各种不同的网站效果.(如下图所示)

如何触发网格呢:

给父元素添加display属性,并且将取值设置成:grid/inline-grid.

grid:

代表的是块状网格,默认独占一行,类似于块级元素.

inline-grid:

代表的是行内块网格,与行内块元素类似

触发网格有哪些特点?

划分行列之后,才能将里面的区域进行划分,才能显示网格,才能进行合并

grid布局与flex布局异同,网格与表格区别?

grid与flex布局:

相同点:

都有容器和项目之分;

不同点:

flex被称之为一维布局,也叫做轴线布局;

grid被称之为二维布局,有行列之分


grid与表格:

相同点:

都有行列之分,都能划分格子;

不同点:

表格嵌套的级别比较深

grid通过容器和项目完成布局

划分行列属性

行属性: grid-template-rows:

列属性: grid-template-columns

重点我们研究的是他们的取值

注意事项:后面跟几组值,就代表了几行几列

取值1:纯数值

{

grid-template-rows:100px 100px 100px;

grid-template-columns:100px 100px 100px;

}


代表的是:
1)划分一个3行3列的网格
2)每一行行高:100px;
3)每一列列宽:100px;

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> .box { margin: 100px auto; width: 500px; height: 500px; border: 10px solid gray; display: grid; grid-template-rows: 100px 100px 100px; grid-template-columns: 100px 100px 100px; } </style> </head> <body> <div class="box"></div> </body> </html>

取值2:百分比

{

grid-template-rows:20% 30% 50%;

grid-template-columns:100px 100px 100px;

}

代表的是:
1)划分一个3行3列的网格;

2)每一行行高:分别是总高的:20% 30% 50%;
3)每一列列宽:100px;

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> .box { margin: 100px auto; width: 500px; height: 500px; border: 10px solid gray; display: grid; grid-template-rows: 20% 30% 50%; grid-template-columns: 100px 100px 100px; } </style> </head> <body> <div class="box"></div> </body> </html>

取值3:重复函数

重复函数:使用的是 repeat(num1,num2)函数

两个参数
参数1: 重复次数
参数2: 需要重复的数值

{

grid-template-rows:repeat(3,100px);

grid-template-columns:repeat(5,20%);

}

代表的是:
1)划分一个3行5列的网格;

2)每一行行高:100px;

3)每一列列宽:均占总宽度的20%;

4)注意:repeat函数,第一个参数是重复的次数,第二个参数为需要重复的数值

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> .box { margin: 100px auto; width: 500px; height: 500px; border: 10px solid gray; display: grid; grid-template-rows: repeat(3, 100px); grid-template-columns: repeat(5, 20%); } </style> </head> <body> <div class="box"></div> </body> </html>

取值4:自动填充

自动填充:auto-fill

应用在重复函数中,代表的是根据需要重复的数值,进行自动填充数量;(例如:以列宽为例子)

{

grid-template-rows:repeat(3,100px);

grid-template-columns:repeat(auto-fill,30%);

}

备注:在这里auto-fill会将列数宽度按照30%的宽度进行划分;盛放不下的话则不再划分列数

{

grid-template-rows:repeat(3,100px);

grid-template-columns:repeat(auto-fill,20%);

}
备注:在这里auto-fill会将列数宽度按照20%的宽度进行划分;盛放不下的话则不再划分列数

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> .box { margin: 100px auto; width: 500px; height: 500px; border: 10px solid gray; display: grid; grid-template-rows: repeat(3, 100px); grid-template-columns: repeat(auto-fill, 30%); } </style> </head> <body> <div class="box"></div> </body> </html>

取值5:auto自动

auto自动代表的是,占剩余宽度和剩余高度的所有,如下图所示

{

grid-template-rows:100px auto 100px;

grid-template-columns:auto 100px 100px;

}

代码的含义是:
设置一个3行3列的网格第1,3行固定高度100px;

第2行高度自适应第2,3列固定宽度100px; 第1列宽度自适应;

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> .box { margin: 100px auto; width: 500px; height: 500px; border: 10px solid gray; display: grid; grid-template-rows: 100px auto 100px; grid-template-columns: auto 100px 100px; } </style> </head> <body> <div class="box"></div> </body> </html>

取值6:fr片段划分

片段划分: 为了方便表示比例关系,网格布局提供了fr关键字(fraction 的缩写,意为“片段")

如果两列的宽度分别为1fr和2fr,就表示后者是前者的两倍

{

grid-template-rows:1fr 2fr 3fr;

grid-template-columns:100px 100px 100px;

}

代码含义:
划分3行3列的网格

其中行高总共划分成6份,

第1行占1/6:

第2行占2/6

第3行占3/6

每一列的宽度为:100px

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> .box { margin: 100px auto; width: 500px; height: 500px; border: 10px solid gray; display: grid; grid-template-rows: 1fr 2fr 3fr; grid-template-columns: 100px 100px 100px; } </style> </head> <body> <div class="box"></div> </body> </html>

取值7:minmax()

minmax(num1,num2)函数,可以理解成最小最大值函数,

函数中两个参数:

参数1代表的是最小值,

参数2代表的是最大值

如果条件允许,则一直使用最大值,

如果条件不满足则使用中间值,

如果剩下的距离不足以显示距离大小,则使用最小值

{

grid-template-rows:100px 100px minmax(100px,200px);

grid-template-columns:100px 100px 100px;

}

{

grid-template-rows:200px 200px minmax(100px,200px);

grid-template-columns:100px 100px 100px;

}

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> .box { margin: 100px auto; width: 500px; height: 500px; border: 10px solid gray; display: grid; grid-template-rows: 100px 100px minmax(100px, 200px); grid-template-columns: 100px 100px 100px; } </style> </head> <body> <div class="box"></div> </body> </html>

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <style> .box { margin: 100px auto; width: 500px; height: 500px; border: 10px solid gray; display: grid; grid-template-rows: 200px 200px minmax(100px, 200px); grid-template-columns: 100px 100px 100px; } </style> </head> <body> <div class="box"></div> </body> </html>

1

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/3 11:14:45

揭秘LoopLLM:大模型Token能耗攻击新路径,一场AI安全的新挑战!

简介 本文揭示了大模型推理过程中的"可用性攻击"威胁&#xff0c;介绍了LoopLLM框架——通过诱导模型陷入重复生成的低熵循环&#xff0c;使其无法自主终止&#xff0c;从而耗尽计算资源。实验证明&#xff0c;LoopLLM在攻击成功率(>90%)和跨模型迁移能力上显著优…

作者头像 李华
网站建设 2026/4/15 14:46:57

关于雷劈数的一些研究

一、雷劈数的定义背景&#xff1a;有个数学家走在路上看见一个 3025 的路牌被劈成 30 和 25 了&#xff0c;他发现 (3025)23025&#xff0c;因此称这种数为雷劈数。比较小的雷劈数有 81(81)2,100(100)2。雷劈数的定义大概为&#xff1a;将数 N的十进制表示从某处分成两半 a和 b…

作者头像 李华
网站建设 2026/4/10 21:36:43

14、优化 Windows 媒体体验:全方位定制指南

优化 Windows 媒体体验:全方位定制指南 在使用 Windows 系统时,Windows Media Player 和 Windows Media Center 为我们提供了丰富的媒体播放和管理功能。通过对它们进行定制,我们可以让媒体体验更加个性化和高效。下面就来详细介绍如何对它们进行定制。 调整 Windows Medi…

作者头像 李华
网站建设 2026/4/7 16:31:47

拒绝丢帧:万字解构安防监控设备的“零拷贝”软核架构

第一章&#xff1a;内存战争——别让带宽扼住了你的喉咙做安防监控的嵌入式开发&#xff0c;很多人有个误区&#xff1a;觉得CPU占用率低就是系统健康。大错特错。在海思、安霸或者瑞芯微这些SoC平台上&#xff0c;把你搞死的往往不是CPU算力不够&#xff0c;而是DDR带宽被打爆…

作者头像 李华
网站建设 2026/4/10 22:28:24

BabylonJS开发:从入门到精通

目录 第一章&#xff1a;启航&#xff01;三维世界的入场券 1.1 WebGL与BabylonJS&#xff1a;你的浏览器里藏着一个宇宙 3D图形学极简史&#xff1a;从三角形到元宇宙 BabylonJS的“超能力清单”&#xff1a;为什么选它&#xff1f; 环境搭建&#xff1a;Node.js、TypeScr…

作者头像 李华
网站建设 2026/4/13 21:05:09

Vite 现代前端构建工具深度解析

Vite 现代前端构建工具深度解析 极速的前端构建体验 ⚡ 引言 在前端开发领域&#xff0c;构建工具的选择直接影响着开发效率和项目性能。Vite 作为一款现代前端构建工具&#xff0c;凭借其极速的冷启动、按需编译和优化的热更新&#xff0c;正在成为越来越多前端开发者的首选。…

作者头像 李华