百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

HTMLCSS学习笔记(二十三)——GRID布局

zhezhongyun 2024-12-05 18:00 23 浏览

GRID布局

它将网页划分成一个个网格,可以任意组合不同的网格,做出各种各样的布局 ?

Grid 布局Flex 布局有一定的相似性,都可以指定容器内部多个项目的位置。但是,它们也存在重大区别。

Flex 布局是轴线布局,只能指定"项目"针对轴线的位置,可以看作是一维布局。

Grid 布局则是将容器划分成"行"和"列",产生单元格,然后指定"项目所在"的单元格,可以看作是二维布局。


grid布局预热

  • 容器和项目
<section>
	<div>
		<p></p>
	</div>
	<div>
		<p></p>
	</div>
	<div>
		<p></p>
	</div>
</section>
<!-- 以上代码section为容器、div为项目 (项目不包括p标签) -->
  • 行和列

容器里面的水平区域称为"行",垂直区域称为"列"。

  • 单元格

行和列的交叉区域,称为"单元格"。

  • 网格线

划分网格的线,称为"网格线"。水平网格线划分出行,垂直网格线划分出列。

GRID属性

容器属性:添加在容器元素

1、启动网格布局

display:grid
/*
 属性值:
  grid  为块状网格容器 (容器自上而下排列)
  line-grid  为内联网格容器(容器横向排列)
*/

2、划分行和列

grid-template-columns:
grid-template-rows:
  • 属性值:绝对大小(根据列数或者行数确定值的个数) 例:200px 200px 200px
grid-template-columns:200px 200px 200px
grid-template-rows:200px 200px 200px
  • 属性值:百分比(根据列数或者行数确定值的个数) 例:33.33% 33.33% 33.33%
grid-template-columns:repeat(auto-fill,33.33%);
/*
 当项目宽高固定,容器不固定的情况下,自动填充网格列数
*/


  • 功能函数:repeat()
grid-template-columns:repeat(auto-fill,33.33%);
/*
 当项目宽高固定,容器不固定的情况下,自动填充网格列数
*/
  • auto-fill关键字( 自动填充 )
grid-template-columns:repeat(auto-fill,33.33%);
/*
 当项目宽高固定,容器不固定的情况下,自动填充网格列数
*/
  • fr关键字(列宽片段)

为了方便表示比例关系,网格布局提供了fr关键字(fraction 的缩写,意为"片段")。如果两列的宽度分别为1fr和2fr,就表示后者是前者的两倍。

grid-template-columns:1fr 3fr 1fr;
grid-template-rows:repeat(3,100px);
  • minmax() 功能函数
grid-template-columns: 1fr 1fr minmax(100px, 1fr);
/*
 minmax(100px, 1fr)表示列宽不小于100px,不大于1fr
*/
  • auto 关键字 自动填充
grid-template-columns:30px auto 20px;
grid-template-rows:repeat(3,100px);


  • 网格线名称
grid-template-columns: [c1] 100px [c2] 100px [c3] auto [c4];
grid-template-rows: [r1] 100px [r2] 100px [r3] auto [r4];
/*
指定网格布局为3行x3列,因此有4根垂直网格线和4根水平网格线。方括号里面依次是这八根线的名字。
*/


3、设置行间距 || 列间距

grid-row-gap:20px /* 行间距 */
grid-column-gap:20px /* 列间距 */
grid-gap:30px 30px /* 复合式写法 */
?
/*注:新版本已经省略 grid- 前缀    row-gap \  column-gap  \  gap*/


  1. 指定"区域"(area),一个区域由单个或多个单元格组成。
display: grid;
grid-template-columns: 100px 100px 100px;
grid-template-rows: 100px 100px 100px;
grid-template-areas: 'a b c'
 'd e f'
 'g h i';
?
/*
 将整个网格容器分为9个区域,每个区域对应一个单元格
 通过grid-area 指定项目名称。
*/


display:grid;
grid-template-columns:repeat(3,100px);
grid-template-rows:repeat(3,100px);
grid-template-areas: 'a a a'
      '. . b'
      '. c c';

5、规划子元素放置的顺序(默认为先排行后排列)

grid-auto-flow: column | row;
/*
 row dense和column dense。
 这两个值主要用于,某些项目指定位置以后,剩下的项目怎么自动放置。
*/

6、设置单元格内容在单元格内 水平 | 垂直 的对齐方式

justify-items: start | end | center | stretch;
align-items: start | end | center | stretch;
place-items:  <justify-items>  <align-items>   /*复合式写法*/
/*
 start:对齐单元格的起始边缘。
    end:对齐单元格的结束边缘。
    center:单元格内部居中。
    stretch:拉伸,占满单元格的整个宽度(默认值)。
*/

7、设置整个内容区域在容器里面的水平 | 垂直 对齐方式

justify-content:start | end | center | stretch | space-around | space-between | space-evenly;
align-content: start | end | center | stretch | space-around | space-between | space-evenly;
place-content:  <justify-content>  <align-content>   /* 复合式写法 */
?
/*
 start - 对齐容器的起始边框。
 end - 对齐容器的结束边框。
 center - 容器内部居中。
 stretch - 项目大小没有指定时,拉伸占据整个网格容器。
 space-around - 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍。
 space-between - 项目与项目的间隔相等,项目与容器边框之间没有间隔。
 pace-evenly - 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔。
*/

项目属性:添加在子元素上面

  1. 指定项目的四个边框,分别定位在哪根网格线。
grid-column-start
grid-column-end
grid-row-start
grid-row-end
?
/*
 grid-column-start属性:左边框所在的垂直网格线
 grid-column-end属性:右边框所在的垂直网格线
 grid-row-start属性:上边框所在的水平网格线
 grid-row-end属性:下边框所在的水平网格线
*/


grid-column-start:1;
grid-column-end:3;
grid-row-start: 2;
grid-row-end:4;

2、grid-column , grid-row

grid-column属性是grid-column-start和grid-column-end的合并简写形式 grid-row属性是grid-row-start属性和grid-row-end的合并简写形式。

grid-column: 1 / 3;
grid-row: 1 / 2;

相关推荐

字体缩放(方式一)(字体缩放150%怎么做)

通过元素宽度和字数计算得到缩放简单实现如下:/***字体最大为视觉要求大小(maxFontSize);超出缩小字体显示,最小为minFontSize;最小字体时超出部分使用圆点(...);*p...

网页世界隐藏的神秘代码语言,竟能这样改变布局

CSS基础:选择器与属性CSS(CascadingStyleSheets)是用于控制网页外观的一门样式表语言。它通过定义HTML元素的显示方式来增强网页的表现力。CSS的选择器允许开发者精确地定位...

CSS属性值计算过程详解(css属性用来定义元素计算)

在CSS中,即使某些属性没有显式声明,浏览器也会通过**属性值计算过程**为每个元素的所有属性赋予最终值。这一过程分为四个关键步骤,以下将逐一解析。1.确定声明值浏览器首先检查所有**直接应用**到...

软网推荐:找回调整Windows 10字号功能

之前的系统,从WindowsXP到早期版本的Windows10,均有字体大小调整功能,但从创意者版Windows10以来,取消了之前的设置选项,取而代之的是自定义缩放比例设置。使用这个功能调整过...

Excel中如何设置文本框属性,实例代码讲解

Excel不仅可以对数据进行处理,而且也可以图形化数据,直观显示数据表达的内容。本节介绍一个很重要的对象,Characters,字符对象,使用Characters对象可修改包含在全文本字符串中的任...

CSS 字体样式(css中字体)

本节我们来讲字体样式,之前我们学习HTML的时候学过一些用于字体加粗、倾斜的标签,但是使用标签来实现的效果肯定没有我们通过CSS中的样式来的方便。接下来我们会给大家介绍下面这几个属性的使用:通...

PC网站建设必备代码知识:HTML基础与应用技巧

在PC网站建设的相关课程里,代码扮演着至关重要的角色。只有熟练运用正确的代码,我们才能打造出功能完善、用户体验出色的PC网站。接下来,我会详细讲解在PC网站建设环节中必须了解的代码知识。HTML基础代...

让你大跌眼镜的疯狂 HTML 和 CSS 技巧

今天,分享一个让你大开眼界的技巧。通过使用这个技巧,你可以将整个网页变成一个CSS编辑器。没错,你从未见过这种方法。当我第一次尝试时,我完全被震惊到了。现在,让我们开始吧!步骤1首先,创建一个基础的...

jQuery EasyUI使用教程:创建一个链接按钮

jQueryEasyUI最新版下载>本教程主要为大家展示如何使用jQueryEasyUI创建一个链接按钮。通常情况下,使用“button/”元素来创建一个按钮;使用“a/”元素来创建链接按钮...

React 19 有哪些新特性?(react100)

如果你对React18还不熟悉,欢迎阅读之前的文章《React18全览[1]》最近React发布了V19RC版本,按照惯例,我们对React19的新特性进行一次深度的体验学习...

Java注解探秘:为什么@PostConstruct能解决你的初始化难题?

你是否在Spring项目中遇到过这样的困扰:明明依赖注入已经完成,但某些配置就是无法正常加载?手动调用初始化方法又容易引发空指针异常?这就是@PostConstruct注解大显身手的时候了!@Post...

AI驱动的表单自动填写(ai置入表格)

我们都同意,填写表格是一项枯燥且耗时的任务。如果我们可以创建一个可以为我们填写表格的AI助手,让我们将时间投入到更有建设性的任务中,那会怎样?AI助手将能够通过调用以表单字段为参数的函数来填写表...

从零到一:小程序设计新手如何快速上手?

开发环境搭建对于小程序设计新手而言,搭建合适的开发环境是首要任务。以小程序为例,其官方提供了功能强大的开发工具——开发者工具。首先,新手需前往官方开发者平台,在页面中找到“工具下载”板块,根据...

JavaSwingGUI从小白到大神-6(续)(java从小白到大牛怎么样)

接上一篇《JavaSwingGUI从小白到大神-6》,因本篇文章3万多字,头条一篇发不完,只能分开发。同事查询面板:CompanyFind.javapublicclassCompanyFind{...

C# winform界面假死(c#程序假死)

针对C#WinForm界面假死问题,以下是分步解决方案:1.使用异步编程(async/await)将耗时操作移至后台线程,保持UI线程响应。步骤:将事件处理函数标记为async。使用Task....