深入CSS 布局——WEB开发系列29
CSS 页面布局技术允许我们拾取网页中的元素,并且控制它们相对正常布局流、周边元素、父容器或者主视口/窗口的位置。

一、正常布局流(Normal Flow)
CSS的布局基础是“正常流”,也就是页面元素在没有特别指定布局方式时的默认排列方式。正常流分为两种主要类型:
- 块级元素:默认情况下,块级元素会独占一行,并且从上到下排列。常见的块级元素有
<div>、<p>、<h1>、<ul>等。 - 行内元素:行内元素不会独占一行,它们会在一行内从左到右排列,直到空间不足再换行。常见的行内元素有
<span>、<a>、<img>等。
举个简单的例子:
<div><p>这是一个段落。</p><p>这是另一个段落。</p>
</div>

两个段落<p>都是块级元素,它们会按照正常流的规则垂直排列。而且,即使你在<p>标签之间加入了许多空格,段落依然会在页面中按照垂直方向排列。
二、Display属性
display属性决定了元素的布局行为。最常见的display值包括block、inline、inline-block、none以及我们将在后文讨论的flex和grid。
- block:将元素定义为块级元素,使其独占一行。
- inline:将元素定义为行内元素,使其在行内排列。
- inline-block:结合了
block和inline的特性,元素本身是行内元素,但可以设置宽高等属性。 - none:完全隐藏元素,元素不占据任何空间。
一个例子展示了这些不同的display值的效果:
<div style="display: block;">这是一个块级元素</div>
<span style="display: inline;">这是一个行内元素</span>
<div style="display: inline-block; width: 100px;">这是一个inline-block元素</div>

display属性是理解CSS布局的基础,它控制了元素在页面上的布局行为。
三、弹性盒子(Flexbox)
弹性盒子(Flexbox)是CSS3引入的一种布局模式,用来为不同尺寸的屏幕设计复杂的布局。通过设置display: flex;,你可以将一个容器变成弹性容器(Flex container),而其内部的子元素则成为弹性项(Flex items)。
1. 设置 display: flex;
将父元素设置为display: flex;后,子元素将自动按照水平(默认)或垂直方向排列,并且能够灵活调整大小以适应容器。
<div style="display: flex;"><div style="background-color: lightblue;">Item 1</div><div style="background-color: lightgreen;">Item 2</div><div style="background-color: lightcoral;">Item 3</div>
</div>

三个子元素在同一行水平排列,因为默认情况下flex-direction是row。
2. 设置 flex 属性
flex属性是弹性盒子的核心,用于设置弹性项如何在弹性容器中分配空间。它通常写作flex: 1;、flex: 2;等,表示子元素在容器中所占的相对比例。
<div style="display: flex;"><div style="flex: 1; background-color: lightblue;">Item 1</div><div style="flex: 2; background-color: lightgreen;">Item 2</div><div style="flex: 1; background-color: lightcoral;">Item 3</div>
</div>

Item 2占据的空间是Item 1和Item 3的两倍。
3. 弹性盒子布局的其他属性
-
justify-content:控制弹性项在主轴(默认水平轴)上的对齐方式。常见值有flex-start(左对齐)、center(居中)、space-between(两端对齐,间隔均匀)等。 -
align-items:控制弹性项在交叉轴(默认垂直轴)上的对齐方式。常见值有stretch(拉伸)、center(居中)、flex-start(顶部对齐)等。
<div style="display: flex; justify-content: space-between; align-items: center;"><div style="background-color: lightblue;">Item 1</div><div style="background-color: lightgreen;">Item 2</div><div style="background-color: lightcoral;">Item 3</div>
</div>

上面的代码展示了如何通过justify-content和align-items控制子元素的排列方式。
四、Grid布局
Grid布局是CSS的一种二维布局系统,可以非常轻松地创建复杂的网页布局。与Flexbox相比,Grid布局能够同时控制行和列。
1. 设置 display: grid;
通过设置display: grid;,你可以将一个容器变成网格容器(Grid container),并在其中定义行和列。
<div style="display: grid; grid-template-columns: 100px 100px 100px; grid-template-rows: 100px 100px;"><div style="background-color: lightblue;">Item 1</div><div style="background-color: lightgreen;">Item 2</div><div style="background-color: lightcoral;">Item 3</div><div style="background-color: lightpink;">Item 4</div>
</div>

网格容器被定义为三列两行,每个单元格大小为100px。子元素将自动填充这些网格单元。
2. 在网格内放置元素
你可以通过grid-column和grid-row属性来指定元素在网格中的位置。
<div style="display: grid; grid-template-columns: 100px 100px 100px; grid-template-rows: 100px 100px;"><div style="background-color: lightblue; grid-column: 1 / 3; grid-row: 1 / 2;">Item 1</div><div style="background-color: lightgreen;">Item 2</div><div style="background-color: lightcoral;">Item 3</div><div style="background-color: lightpink;">Item 4</div>
</div>

此例中,Item 1占据了网格的前两列和第一行。
3. Grid布局的其他属性
-
gap:设置网格单元格之间的间隔。 -
grid-template-areas:定义命名网格区域,可以用于创建更语义化的布局。
<div style="display: grid; grid-template-columns: 1fr 1fr 1fr; grid-template-areas: 'header header header''sidebar content content''footer footer footer';"><div style="grid-area: header; background-color: lightblue;">Header</div><div style="grid-area: sidebar; background-color: lightgreen;">Sidebar</div><div style="grid-area: content; background-color: lightcoral;">Content</div><div style="grid-area: footer; background-color: lightpink;">Footer</div>
</div>

通过grid-template-areas,我们创建了一个包含头部、侧边栏、内容区和底部的布局。
五、浮动(Float)
浮动是CSS中的一个经典布局方法,用于将元素从正常流中移出,并使其在父容器内左右浮动。通过设置float: left;或float: right;,可以使元素分别浮动到父容器的左侧或右侧。
<div style="overflow: hidden;"><img src="image.jpg" style="float: left; margin-right: 20px;"><p>这是一个浮动示例,图片将浮动到左侧,文本将围绕在图片周围。</p>
</div>

在这个例子中,图片浮动到左侧,文本则环绕在图片右侧。
需要注意的是,浮动元素之后的内容通常会出现“塌陷”问题,即元素的父容器高度会变为0。解决方法是在浮动元素之后使用清除浮动(clear)技术:
.clearfix::after {content: "";display: table;clear: both;
}
使用.clearfix类可以确保父容器包裹住浮动的子元素。
六、定位技术(Position)
CSS定位是通过设置position属性来改变元素在文档中的位置。主要的定位方式包括:
1. 简单定位示例
简单的定位属性包括static(默认)、relative、absolute、fixed和sticky。
<div style="position: relative; top: 20px; left: 30px;">这是一个相对定位的元素
</div>

2. 相对定位(Relative)
相对定位使元素相对于其正常位置进行移动。它不会影响文档流中其他元素的布局。
<div style="position: relative; top: 10px; left: 15px;">这是一个相对定位的元素
</div>

元素相对于其原始位置向下移动了10px,向右移动了15px。
3. 绝对定位(Absolute)
绝对定位的元素相对于最近的已定位祖先元素进行定位(如果没有,则相对于初始包含块)。绝对定位的元素脱离了文档流,不会影响其他元素的布局。
<div style="position: relative;"><div style="position: absolute; top: 0; right: 0;">这是一个绝对定位的元素</div>
</div>

内部的绝对定位元素相对于其父元素的右上角进行定位。
4. 固定定位(Fixed)
固定定位的元素相对于浏览器窗口进行定位,即使页面滚动,元素也会保持在固定位置。
<div style="position: fixed; bottom: 0; right: 0;">这是一个固定定位的元素
</div>

一个固定在浏览器窗口右下角的元素,即使页面滚动,它的位置也不会改变。
5. 粘性定位(Sticky)
粘性定位结合了相对定位和固定定位的特点,当元素在页面中滚动到一定位置时,会“粘”住并保持在该位置。
<div style="position: sticky; top: 0; background-color: yellow;">这是一个粘性定位的元素
</div>

当页面滚动时,元素会在到达顶部时固定在顶部。
七、表格布局
表格布局是一种老式但仍然有效的布局方式,特别适用于展示结构化数据。表格布局使用<table>、<tr>、<td>等标签定义行和列。
<table border="1"><tr><th>姓名</th><th>年龄</th></tr><tr><td>张三</td><td>28</td></tr><tr><td>李四</td><td>24</td></tr>
</table>

上述示例如何使用表格布局来展示数据。
八、多列布局
多列布局(Multi-column Layout)是一种将内容分为多个列的布局方式,类似于报纸的排版。通过column-count和column-width等属性,可以轻松实现多列布局。
<div style="column-count: 3; column-gap: 20px;">这是一个多列布局的示例。通过使用CSS的多列布局属性,我们可以将内容分为多个列。这种布局方式非常适合用于展示较长的文本内容,如新闻文章或博客文章。
</div>

文本被分成了三列,并且列与列之间有20px的间隔。
九、CSS布局综合练习题
为了更好地理解这些布局技术,我们来看看两个综合练习题,并提供相应的代码示例。
题1:创建一个三栏布局
使用Flexbox创建一个响应式三栏布局,其中左栏和右栏固定宽度,中间栏自适应剩余空间。
<div style="display: flex;"><div style="flex: 0 0 200px; background-color: lightblue;">左栏</div><div style="flex: 1; background-color: lightgreen;">中间栏</div><div style="flex: 0 0 200px; background-color: lightcoral;">右栏</div>
</div>

题2:创建一个简单的网格布局
使用Grid布局创建一个三行三列的网格,其中第一行的两个单元格合并为一个单元格,第三行的三个单元格合并为一个单元格。
<div style="display: grid; grid-template-columns: repeat(3, 1fr); grid-gap: 10px;"><div style="grid-column: span 2; background-color: lightblue;">合并两个单元格</div><div style="background-color: lightgreen;">单元格2</div><div style="background-color: lightcoral;">单元格3</div><div style="background-color: lightpink;">单元格4</div><div style="grid-column: span 3; background-color: lightgray;">合并三个单元格</div>
</div>


如有表述错误及欠缺之处敬请指正补充。
相关文章:
深入CSS 布局——WEB开发系列29
CSS 页面布局技术允许我们拾取网页中的元素,并且控制它们相对正常布局流、周边元素、父容器或者主视口/窗口的位置。 一、正常布局流(Normal Flow) CSS的布局基础是“正常流”,也就是页面元素在没有特别指定布局方式时的默认排列…...
视频的容器格式和编码格式详解
视频的容器格式和编码格式是视频文件的两个核心概念,它们相互关联但具有不同的功能。以下是详细的解释: 1. 容器格式 (Container Format) 容器格式,又称封装格式,指的是视频文件的外壳或容器,它用于封装视频、音频、…...
Elasticsearch Mapping 详解
1 概述 映射的基本概念 Mapping 也称之为映射,定义了 ES 的索引结构、字段类型、分词器等属性,是索引必不可少的组成部分。 ES 中的 mapping 有点类似与DB中“表结构”的概念,在 MySQL 中,表结构里包含了字段名称,字…...
WPF 利用视觉树获取指定名称对象、指定类型对象、以及判断是否有验证错误
1.利用视觉树获取指定名称对象 /// <summary> /// Finds a Child of a given item in the visual tree. /// </summary> /// <param name"parent">A direct parent of the queried item.</param> /// <typeparam name"T">T…...
了解`re`模块的`split()`, `sub()`, `subn()`方法的作用
在Python中,re模块(即正则表达式模块)提供了强大的字符串处理能力,允许你通过模式匹配来执行复杂的文本搜索、替换和分割等操作。其中,split(), sub(), 和 subn() 方法是re模块中非常实用的几个函数,它们各…...
机器学习交通流量预测实现方案
机器学习交通流量预测实现方案 实现方案 1. 数据预处理 2. 模型选择 3. 模型训练与评估 代码实现 代码解释 小结 🎈边走、边悟🎈迟早会好 交通流量预测是机器学习在智能交通系统中的典型应用,通常用于预测道路上的车辆流量、速度和拥…...
QNN:基于QNN+example重构之后的yolov8det部署
QNN是高通发布的神经网络推理引擎,是SNPE的升级版,其主要功能是: 完成从Pytorch/TensorFlow/Keras/Onnx等神经网络框架到高通计算平台的模型转换; 完成模型的低比特量化(int8),使其能够运行在高…...
Redis实战宝典:开发规范与最佳实践
目录标题 Key命名设计:可读性、可管理性、简介性Value设计:拒绝大key控制Key的生命周期:设定过期时间时间复杂度为O(n)的命令需要注意N的数量禁用命令:KEYS、FLUSHDB、FLUSHALL等不推荐使用事务删除大key设置合理的内存淘汰策略使…...
RPC的实现原理架构
RPC(Remote Procedure Call,远程过程调用)是一种允许程序调用位于不同地址空间或网络上的函数或方法的技术,尽管这些调用看起来像是本地调用。RPC 的实现极大地简化了分布式系统中的通信,避免了开发人员直接处理底层网…...
OpenXR Monado Hello_xr提交Frame
OpenXR Monado Hello_xr提交Frame @src/tests/hello_xr/openxr_program.cpp RenderFrame())xrWaitFrame(m_session, &frameWaitInfo, &frameState)xrBeginFrame(m_session, &frameBeginInfo)std::vector<XrCompositionLayerBaseHeader*> layers;std::vecto…...
huggingface快速下载模型及其配置
大家知道,每次进huggingface里面一个个手动下载文件然后再上传到我们的服务器是很麻烦的。其实huggingface提供了下载整个包的命令,很简单,如下: 1. 进入huggingface官网,随便搜索一个模型,点击右上角的三…...
虚幻5|不同骨骼受到不同伤害|小知识(2)
1.蓝图创建一个结构,B_BoneDamage 结构里添加一个浮点变量,表示伤害倍数 2.当我们创建了一个结构,就需要创建一个数据表格,数据表格可以选择对应的结构 不同骨骼不同倍数伤害,骨骼要对应骨骼网格体的名称 3.把我们br…...
达梦SQL 优化简介
目录 一、定位慢 SQL (一)开启跟踪日志记录 1.跟踪日志记录配置 (二)通过系统视图查看 1.SQL 记录配置 2.查询方式 二、SQL分析方法 (一)执行计划 1.概述 2.查看执行计划 (二&#x…...
题解:CF1070B Berkomnadzor
CF1070B Berkomnadzor 题解 解题思路 不难想到将 IP 地址转化为二进制后插入一个字典树中,转化后二进制的长度就是 x x x 的长度。我们需要记录每个串结尾的颜色,不妨设黑名单为 1 1 1,白名单为 0 0 0,初始时每个位置的颜色是…...
shell 学习笔记:数组
目录 1. 定义数组 2. 读取数组元素值 3. 关联数组 4. 在数组前加一个感叹号 ! 可以获取数组的所有键 5. 在数组前加一个井号 # 获取数组的长度 6. 数组初始化的时候,也可以用变量 7. 循环输出数组的方法 7.1 for循环输出 7.2 while循环输出 7.2.1 …...
计算机基础知识复习9.5
数据交换 电路交换:交换信息的两个主机之间简历专用通道,传输时延小,实时性强,效率低,无法纠正错误。 报文交换:信息拆分成小包(报文)大小无限制,有目的/源等信息提高利用率。有转…...
spark.sql
from pyspark.sql import SparkSession from pyspark.sql.functions import col, count, mean, rank, row_number, desc from pyspark.sql.window import Window from pyspark.sql.types import StructType, StructField, StringType, IntegerType# 初始化 SparkSession 对象 s…...
2024 数学建模高教社杯 国赛(A题)| “板凳龙”舞龙队 | 建模秘籍文章代码思路大全
铛铛!小秘籍来咯! 小秘籍团队独辟蹊径,运用等距螺线,多目标规划等强大工具,构建了这一题的详细解答哦! 为大家量身打造创新解决方案。小秘籍团队,始终引领着建模问题求解的风潮。 抓紧小秘籍&am…...
kaggle注册收不到验证码、插件如何下载安装
综合这三个来看, 1.插件下载用的大佬给的分享链接 2.下载好压缩包以后需要解压缩 Header Editor插件网盘下载安装教程 - 哔哩哔哩 (bilibili.com) 3.安装插件时没找到crx文件,在浏览器插件界面点击“加载解压缩的扩展” 4.复制网址到插件里ÿ…...
k8s相关技术栈
文章目录 一、k8s技术栈核心组件常见工具和服务生态系统 二、k8s服务组件控制平面组件节点组件附加组件和服务 三、k8s 常见资源核心资源扩展资源 四、系列文档其他参考 一、k8s技术栈 Kubernetes(常被简称为 K8s,其中 “K” 代表 “Kubernetes” 的首字…...
树莓派超全系列教程文档--(62)使用rpicam-app通过网络流式传输视频
使用rpicam-app通过网络流式传输视频 使用 rpicam-app 通过网络流式传输视频UDPTCPRTSPlibavGStreamerRTPlibcamerasrc GStreamer 元素 文章来源: http://raspberry.dns8844.cn/documentation 原文网址 使用 rpicam-app 通过网络流式传输视频 本节介绍来自 rpica…...
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする
日语学习-日语知识点小记-构建基础-JLPT-N4阶段(33):にする 1、前言(1)情况说明(2)工程师的信仰2、知识点(1) にする1,接续:名词+にする2,接续:疑问词+にする3,(A)は(B)にする。(2)復習:(1)复习句子(2)ために & ように(3)そう(4)にする3、…...
聊聊 Pulsar:Producer 源码解析
一、前言 Apache Pulsar 是一个企业级的开源分布式消息传递平台,以其高性能、可扩展性和存储计算分离架构在消息队列和流处理领域独树一帜。在 Pulsar 的核心架构中,Producer(生产者) 是连接客户端应用与消息队列的第一步。生产者…...
1.3 VSCode安装与环境配置
进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件,然后打开终端,进入下载文件夹,键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...
【2025年】解决Burpsuite抓不到https包的问题
环境:windows11 burpsuite:2025.5 在抓取https网站时,burpsuite抓取不到https数据包,只显示: 解决该问题只需如下三个步骤: 1、浏览器中访问 http://burp 2、下载 CA certificate 证书 3、在设置--隐私与安全--…...
现代密码学 | 椭圆曲线密码学—附py代码
Elliptic Curve Cryptography 椭圆曲线密码学(ECC)是一种基于有限域上椭圆曲线数学特性的公钥加密技术。其核心原理涉及椭圆曲线的代数性质、离散对数问题以及有限域上的运算。 椭圆曲线密码学是多种数字签名算法的基础,例如椭圆曲线数字签…...
ArcGIS Pro制作水平横向图例+多级标注
今天介绍下载ArcGIS Pro中如何设置水平横向图例。 之前我们介绍了ArcGIS的横向图例制作:ArcGIS横向、多列图例、顺序重排、符号居中、批量更改图例符号等等(ArcGIS出图图例8大技巧),那这次我们看看ArcGIS Pro如何更加快捷的操作。…...
Go 语言并发编程基础:无缓冲与有缓冲通道
在上一章节中,我们了解了 Channel 的基本用法。本章将重点分析 Go 中通道的两种类型 —— 无缓冲通道与有缓冲通道,它们在并发编程中各具特点和应用场景。 一、通道的基本分类 类型定义形式特点无缓冲通道make(chan T)发送和接收都必须准备好࿰…...
uniapp手机号一键登录保姆级教程(包含前端和后端)
目录 前置条件创建uniapp项目并关联uniClound云空间开启一键登录模块并开通一键登录服务编写云函数并上传部署获取手机号流程(第一种) 前端直接调用云函数获取手机号(第三种)后台调用云函数获取手机号 错误码常见问题 前置条件 手机安装有sim卡手机开启…...
FFmpeg:Windows系统小白安装及其使用
一、安装 1.访问官网 Download FFmpeg 2.点击版本目录 3.选择版本点击安装 注意这里选择的是【release buids】,注意左上角标题 例如我安装在目录 F:\FFmpeg 4.解压 5.添加环境变量 把你解压后的bin目录(即exe所在文件夹)加入系统变量…...
