体验css:repeat和grid

news/2024/11/25 21:58:50/

文章目录

  • 一、repeat
    • 1. 语法
    • 2. auto-fill和auto-fit
    • 3. 专属尺寸
      • ① fr
      • ② auto
      • ③ max-content
      • ④ min-content
  • 二、grid
    • 1. 设置grid布局
    • 2. 设置列宽行高
    • 3. 设置间距
    • 4. 设置分区
    • 5. 设置布局排列顺序
    • 6. 设置单元格内容对齐方式
    • 7. 设置整个网格对齐方式
    • 8. 设置隐式网格大小
    • 9. 设置网格位置

一、repeat

要想了解grid布局,首先了解 repeat() 的作用。

1. 语法

  • 见名知意,repeat() 函数表示轨道列表的重复片段。
  • 目前只有放在 grid-template-columnsgrid-template-rows 上才有效。
  • 语法:repeat([auto-fill | auto-fit | <integer>] , [<line-names> ? [<fixed-size> | <track-size>]] + <line-names>?)
    • 轨道:一行叫行轨道,一列叫列轨道。
    • 第一个参数:auto-fillauto-fit 会尽量在(一行/一列,看用的是...columns还是...rows)多创建轨道。重复次数就是重复创建多少次。
    • 第二个参数:轨道名、轨道尺寸。
    • 示例:repeat(4, [col-name] 1fr [col-name] 20px)
      在这里插入图片描述

2. auto-fill和auto-fit

在这里插入图片描述

  • 我比较喜欢用 auto-fit,可以填满整个父元素。
  • 不能只使用 fr、auto、min-content、max-content,否则一个占一行。比如:repeat(auto-fill, 1fr min-content)
  • 在 子元素总宽度 <= 父元素宽度时,差异比较明显:
<body>
<div class="container"><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div>
</div>
<div id="container"><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div>
</div>
</body>
<style>.container {display: grid;width: 600px;background-color: #ccc;grid-gap: 5px;grid-template-columns: repeat(auto-fit, minmax(20px, 1fr));border: 1px dashed skyblue;}#container {display: grid;width: 600px;background-color: skyblue;grid-gap: 5px;grid-template-columns: repeat(auto-fill, minmax(20px, 1fr));border: 1px dashed skyblue;}
</style>

在这里插入图片描述

  • 在 子元素总宽度 > 父元素宽度时,没什么差异:
    .container {...grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));...}#container {...grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));...}

在这里插入图片描述

3. 专属尺寸

① fr

  • fr 单位代表网格容器中可用空间的一等份

② auto

  • 由浏览器决定长度。
  • 作为最大值,等同于 max-content。作为最小值,它代表占据网格轨道的网格项目的最小尺寸的最大值(如同min-width/min-height所指定的))。
<body>
<div class="container"><div style="border: 1px solid black;height: 50px;">225255656sad56561</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div>
</div>
</body>
<style>.container {display: grid;width: 300px;background-color: #ccc;grid-gap: 5px;grid-template-columns: repeat(1, auto 20px);border: 1px dashed skyblue;}
</style>

在这里插入图片描述

③ max-content

  • 代表占据网格轨道的网格项目所分配的最大内容区域的最大值。
<body>
<div class="container"><div style="border: 1px solid black;height: 50px;">225255656sad56561</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div>
</div>
</body>
<style>.container {display: grid;width: 300px;background-color: #ccc;grid-gap: 5px;grid-template-columns: repeat(1, max-content 20px);border: 1px dashed skyblue;}
</style>

在这里插入图片描述

④ min-content

  • 代表占据网格轨道的网格项目所分配的最小内容区域的最小值。
<body>
<div class="container"><div style="border: 1px solid black;height: 50px;">225255656sad56561</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div><div style="border: 1px solid black;height: 50px;">1</div>
</div>
</body>
<style>.container {display: grid;width: 300px;background-color: #ccc;grid-gap: 5px;grid-template-columns: repeat(1, min-content 20px);border: 1px dashed skyblue;}
</style>

在这里插入图片描述

二、grid

1. 设置grid布局

  • display: grid:块级元素。
<body>
1
<div id="container"><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
2
</body>
<style>#container {display: grid;grid: repeat(2, 60px) / auto-flow 80px;}#container > div {background-color: #8ca0ff;width: 50px;height: 50px;}
</style>

在这里插入图片描述

  • display: inline-grid:行内元素。
<body>
1
<div id="container"><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
2
</body>
<style>#container {display: inline-grid;grid: repeat(2, 60px) / auto-flow 80px;}#container > div {background-color: #8ca0ff;width: 50px;height: 50px;}
</style>

在这里插入图片描述

  • grid:可以用来设置多个属性。比如grid-template-rows、grid-template-columns 和 grid-template-areas等等。类似于 background 可以设置 bgColor、bgPosition。

2. 设置列宽行高

  • grid-template:用以定义网格中行、列与分区。
  • grid-template-columns:基于网格列的维度,定义网格线的名称和网格轨道的尺寸大小
  • grid-template-rows:基于网格行的维度,定义网格线的名称和网格轨道的尺寸大小
<body>
<div id="container"><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
</body>
<style>#container {display: inline-grid;grid-gap: 5px;grid-template-columns: repeat(2, 50px);grid-template-rows: repeat(4, 50px);}#container > div {background-color: #8ca0ff;width: 50px;height: 50px;}
</style>

在这里插入图片描述

3. 设置间距

  • grid-row-gap:行间距
  • grid-column-gap:列间距
  • grid-gap:行列间距
<body>
<div id="container"><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
</body>
<style>#container {display: inline-grid;grid-column-gap: 10px;grid-row-gap: 20px;grid-template-columns: repeat(2, 50px);grid-template-rows: repeat(4, 50px);}#container > div {background-color: #8ca0ff;width: 50px;height: 50px;}
</style>

在这里插入图片描述

4. 设置分区

  • grid-template-areas 用于划分网格区域。
  • grid-area 用于指定网格所属哪个区域。
  • 取名的名字自己取,. 表示不会用到这个区域。
<body>
<div id="container"><header>header</header><nav>nav</nav><main>main</main><footer>footer</footer>
</div>
</body>
<style>#container {display: grid;grid-template-columns: 50px 200px;grid-template-rows: 50px 200px 50px;grid-template-areas: ". head""nav main""foot foot";}header {grid-area: head;background-color: #fedcba;}nav {grid-area: nav;background-color: #abcdef;}main {grid-area: main;background-color: #654321;}footer {grid-area: foot;background-color: #98abcd;}
</style>

在这里插入图片描述

5. 设置布局排列顺序

  • grid-auto-flow 控制着自动布局算法怎样运作,精确指定在网格中被自动布局的元素怎样排列。(指定排列顺序)
  • 语法:grid-auto-flow: [ row | column ] || dense
  • 默认时row,即把一行填满再填下一行。
  • column:列顺序。
  • dense:指定自动布局算法使用一种“稠密”堆积算法,如果后面出现了稍小的元素,则会试图去填充网格中前面留下的空白。这样做会填上稍大元素留下的空白,但同时也可能导致原来出现的次序被打乱。

6. 设置单元格内容对齐方式

  • 用于设置单元格内容在单元格内的对齐方式。
  • justify-items:内容水平对齐(start | end | center | stretch)。
  • align-items:内容垂直对齐(start | end | center | stretch)。
  • place-items:可以同时设置垂直对齐和水平对齐。
  • 默认值是 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:同时设置垂直对齐和水平对齐。
<body>
<div id="grid"><div>1</div><div>2</div><div>3</div><div>4</div><div>5</div><div>6</div><div>7</div><div>8</div><div>9</div>
</div>
</body>
<style>#grid {height: 500px;width: 500px;display: grid;grid-gap: 10px;grid-template: repeat(3, 50px) / repeat(3, 50px);grid-auto-flow: row;background-color: #f70;place-items: stretch stretch;/* space-around space-between space-evenly */justify-content: space-around; }#grid > div{background-color: #acd;}
</style>

在这里插入图片描述

8. 设置隐式网格大小

  • 如果一个表格项目被定位在没有使用 grid-template-columns 显式指定尺寸的列中,隐式的 grid 轨道就会被创建出来支撑它。显式地定位到超出范围的列中,或者通过自动布局算法创建额外的列,就会发生上述情况。
  • 翻译一下上面的:如果只设置了两列列宽,那这两列是显式网格,其他都是隐式网格(因为没设置到)。
  • grid-auto-rowsgrid-auto-columns设置隐式网格大小。
<body>
<div id="grid"><div id="item1"></div><div id="item2"></div><div id="item3"></div>
</div>
</body>
<style>#grid {height: 100px;display: grid;grid-template-areas: "a a";grid-gap: 10px;grid-auto-columns: 200px;}#grid > div {background-color: lime;}
</style>

在这里插入图片描述

9. 设置网格位置

  • grid-column-start、grid-column-end、grid-row-start、grid-row-end:设置网格的行列开始或结束在哪个位置。
  • 属性值:auto为自动放置,area-name 4 为该区域的第四行/列。
<body>
<div class="wrapper"><div class="box1">One</div><div class="box2">Two</div><div class="box3">Three</div><div class="box4">Four</div><div class="box5">Five</div>
</div>
</body>
<style>.wrapper {display: grid;grid-template-columns: repeat(3, 1fr);grid-auto-rows: 100px;}.wrapper > div {border: 1px solid #000;}.box1 {grid-column-start: 1;grid-column-end: 4;grid-row-start: 1;grid-row-end: 3;}.box2 {grid-column-start: 1;grid-row-start: 3;grid-row-end: 5;}
</style>

在这里插入图片描述


http://www.ppmy.cn/news/75049.html

相关文章

波奇学Linux:时间指令,查找指令,压缩指令,热键

日志&#xff1a;时间&#xff0c;日志等级&#xff0c;日志具体信息&#xff0c;其他信息用来记录程序信息 时间指令 data指令显示时间 修改时间显示格式 时间戳&#xff1a; date %s 时间戳&#xff1a;统一的时间格式&#xff0c;因为有时差原因&#xff0c;时间相对于各…

C++爱好者的自我修养(12.1):数据类型——整型

文章目录 数据类型——整型1.1 短整型1.1.1 有符号1.1.2 无符号 1.2 整型1.2.1 有符号1.2.2 无符号 1.3 长整型1.3.1 有符号1.3.2 无符号 1.4 超长整型1.4.1 有符号1.4.2 无符号 数据类型——整型 1.1 短整型 1.1.1 有符号 类型标识符&#xff1a;short 占节字数&#xff1a…

玄子Share - mybatis-3.5.13 学习笔记

玄子Share - mybatis-3.5.13 学习笔记 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-edDRdx4N-1684580838688)(./assets/68747470733a2f2f6d7962617469732e6f72672f696d616765732f6d7962617469732d6c6f676f2e706e67.png)] mybatis 官网 官网 htt…

zabbix企业监控实战-1-zabbix部署

官网&#xff1a;https://www.zabbix.com 参考官网&#xff1a;https://www.zabbix.com/download?zabbix6.0&os_distributionrocky_linux&os_version8&componentsserver_frontend_agent&dbmysql&wsapache 1、环境准备 1> 修改主机名 [rootzabbix ~]# h…

mkfs.vfat以及mkfs.ext4命令详解

文章目录 前言&#xff1a;mkfs.vfat/mkfs.fatmkfs.ext4 前言&#xff1a; 做磁盘格式化(文件系统创建) 的时候发现网上对于mkfs.vfat和mkfs.ext4的命令解释都不多&#xff0c;这边就特地整理一下&#xff0c;虽然用man就可以查看&#xff0c;但是懒人嘛&#xff0c;还是喜欢看…

自己动手写一个加载器

前言 当在 linux 命令行中 ./ 运行一个程序时&#xff0c;实际上操作系统会调用加载器将这个程序加载到内存中去执行。为了探究加载器的行为&#xff0c;今天我们就自己动手写一个简单的加载器。 工作原理 加载器的工作原理&#xff1a; 从磁盘读取 bin 文件到内存&#xf…

Maven 入门教程

Maven是专门为Java项目打造的项目管理和构建工具&#xff0c;类似 NodeJS 的 NPM&#xff0c;PHP 的 composer。 官网&#xff1a;https://maven.apache.org/ 它的主要功能有&#xff1a; 提供了一套标准化的项目结构&#xff1b;提供了一套标准化的构建流程&#xff08;编译…

AcWing 826. 单链表(C++)

目录 1.题目描述 2.AC 1.题目描述 826. 单链表 实现一个单链表&#xff0c;链表初始为空&#xff0c;支持三种操作&#xff1a; 向链表头插入一个数&#xff1b;删除第 kk 个插入的数后面的数&#xff1b;在第 kk 个插入的数后插入一个数。 现在要对该链表进行 MM 次操作…