“弹性盒子”一维布局系统(补充)——WEB开发系列31

弹性盒子是一种一维布局方法,用于根据行或列排列元素。元素可以扩展以填补多余的空间,或者缩小以适应较小的空间,为容器中的子元素提供灵活的且一致的布局方式。


一、什么是弹性盒子?

CSS 弹性盒子(Flexible Box Layout,简称 Flexbox)是 CSS3 中引入的一种布局模式,提供一种有效的方式来布局、对齐和分配容器内空间,特别是在动态和复杂的应用界面中。


1、弹性盒子的基本概念

  • 弹性容器(Flex Container):通过设置 ​​display: flex​​ 或 ​​display: inline-flex​​ 创建,成为弹性盒子的上下文。
  • 弹性项目(Flex Items):弹性容器中的直接子元素,它们的布局和行为会受到弹性容器的控制。

2、Flexbox 的优势

  1. 易于实现响应式布局:无论屏幕大小,Flexbox 都能轻松处理元素的排列和对齐。
  2. 空间分配的灵活性:能够方便地调整子元素大小和位置,以适应不同浏览器窗口或设备。
  3. 对齐和排序更直观:使用 Flexbox 可以简化项目的对齐方式及其在容器内的显示顺序。

我们先来看看一个简单的示例,包含多个子元素的弹性盒子。

<!DOCTYPE html>
<html lang="zh">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Flexbox 示例</title><style>.container {display: flex;  /* 设置为弹性盒子 */border: 1px solid #ccc; /* 添加边框 */padding: 10px;}.item {background-color: #4CAF50;color: #fff;padding: 15px;margin: 5px; /* 为每个项添加间距 */flex: 1; /* 所有项均等分配空间 */}</style>
</head>
<body><div class="container"><div class="item">项目 1</div><div class="item">项目 2</div><div class="item">项目 3</div></div>
</body>
</html>

我们创建了一个弹性盒子容器 ​​.container​​,并包含了三个子元素(弹性项目)。通过设置 ​​display: flex​​​,子项将自动适应容器的宽度。


二、指定元素的布局为 Flexible

要将元素的布局指定为弹性盒子,只需在 CSS 中为容器添加 ​​display: flex​​​。这告诉浏览器将该元素视为弹性容器。

.container {display: flex; /* 创建弹性容器 */
}

通过这种设置,容器内部的所有子元素都会自动成为弹性项目,并享有 Flexbox 提供的布局能力。


三、Flex 模型说明

Flexbox 的基本结构可以总结为两个部分:弹性容器和弹性项目。

  1. 弹性容器:容器是 Flexbox 布局的基础。它控制了如何排列其内部的弹性项目。
  2. 弹性项目:容器里面的元素。在大多数情况下,只有容器的直接子元素才是弹性项目。

当元素表现为 flex 框时,它们沿着两个轴来布局:

主轴(main axis)是指沿着弹性盒子(flex item)放置方向延伸的轴,可以是页面上的横向行或纵向列。主轴的起点和终点分别称为主起点(main start)和主终点(main end)。

交叉轴(cross axis)则是与主轴垂直的方向,其起点和终点被称为交叉起点(cross start)和交叉终点(cross end)。

当父元素设置为 ​​display: flex​​ 时,它被称为弹性容器(flex container)。而在该容器中表现为弹性盒子的元素被称为弹性项(flex item)。


四、列还是行?

默认情况下,Flexbox 将项目在行的方向排列。然而,开发者可以使用 ​​flex-direction​​ 属性设置项目在容器中的排列方向,这个属性可以取以下值:

  • row(默认值):项目在水平方向上从左到右排列。
  • row-reverse:项目在水平方向上从右到左排列。
  • column:项目在垂直方向上从上到下排列。
  • column-reverse:项目在垂直方向上从下到上排列。

示例:改变排列方向

.container {display: flex;flex-direction: column; /* 垂直排列 */
}

通过更改 ​​flex-direction​​​ 属性,项目的排列方式从水平变为垂直。


五、换行

有时,弹性项目的总宽度可能会超过容器的宽度。在这种情况下,默认情况下,Flexbox 会缩小弹性项目以适应容器。为了允许换行,可以使用 ​​flex-wrap​​ 属性进行设置。

  • nowrap(默认值):所有项目在单行中显示。
  • wrap:允许根据容器的宽度换行。
  • wrap-reverse:反向换行,最后一行显示在最上面。

示例:使用换行

.container {display: flex;flex-wrap: wrap; /* 允许换行 */
}

此设置让弹性项目在容器宽度不足时自动换行。


六、flex-flow 缩写

​flex-flow​​ 是 ​​flex-direction​​ 和 ​​flex-wrap​​ 的缩写。可以同时设置方向以及换行行为。

示例:使用 flex-flow

.container {display: flex;flex-flow: row wrap; /* 水平排列并允许换行 */
}

通过这种方式,容器内的项目将水平排列并且在不足容纳时自动换行。


七、Flex 项的动态尺寸

CSS 弹性盒子允许用户动态地分配项目的空间。这个功能依靠 ​​flex​​ 属性,它是 ​​flex-grow​​、​​flex-shrink​​ 和 ​​flex-basis​​ 的缩写:

  • flex-grow:定义项目的放大比例,默认为 0,表示不放大。
  • flex-shrink:定义项目的缩小比例,默认为 1,也就是说,项目能够缩小以适应容器。
  • flex-basis:定义项目的初始大小,默认为 ​​auto​​,项目的大小会基于内容。

示例:使用 flex 属性

.item-1 {flex: 2; /* 占 2 份空间 */
}
.item-2 {flex: 1; /* 占 1 份空间 */
}
.item-3 {flex: 1; /* 占 1 份空间 */
}

示例中,item-1 将占据比其他两个项目更多的空间。


八、flex:缩写与全写

使用 ​​flex​​ 属性的缩写格式,即可以同时设置 ​​flex-grow​​、​​flex-shrink​​ 和 ​​flex-basis​​:

.item {flex: 1; /* 等同于 flex-grow: 1; flex-shrink: 1; flex-basis: 0%; */
}

这种缩写方式让我们在 CSS 中显得更为简洁和清晰。


九、水平和垂直对齐

Flexbox 允许开发者轻松实现元素的对齐,包括水平和垂直对齐。


1、justify-content(水平对齐)

​justify-content​​ 属性控制项目在主轴上的对齐方式,常用值包括:

  • flex-start:项目从容器的起始位置对齐。
  • flex-end:项目从容器的结束位置对齐。
  • center:项目在主轴中心对齐。
  • space-between:项目之间的间距均等。
  • space-around:项目间距相等且与容器边缘的间距相等。

示例:使用 justify-content

.container {display: flex;justify-content: center; /* 项目居中对齐 */
}

2、align-items(垂直对齐)

​align-items​​ 属性控制项目在交叉轴上的对齐方式,常用值包括:

  • flex-start:项目在交叉轴上端对齐。
  • flex-end:项目在交叉轴下端对齐。
  • center:项目在交叉轴中心对齐。
  • baseline:项目基线对齐。
  • stretch:项目拉伸以填满容器的高度。

示例:使用 align-items

.container {display: flex;align-items: stretch; /* 项目占满容器的高度 */
}

通过这两个对齐属性,可以轻松地实现不同的布局需求。


十、Flex 项排序

Flexbox 允许我们对项目的显示顺序进行重新排列,通过 ​​order​​ 属性来实现。默认值为 0,值越小的项目显示顺序越靠前。

示例:使用 order 属性

.item-1 {order: 2; /* 移到第二 */
}
.item-2 {order: 1; /* 移到第一 */
}
.item-3 {order: 3; /* 保持在第三 */
}

在这段代码中,虽然 ​​item-1​​ 在 HTML 结构中是第一个,但由于设置了 ​​order​​​ 属性,它将显示在第二。


十一、Flex 嵌套

在实际开发中,我们经常需要将一个弹性盒子嵌套在另一个弹性盒子内。这样可以实现复杂的布局。

示例:弹性盒子嵌套

<div class="outer-container"><div class="inner-container"><div class="item">内层项目 1</div><div class="item">内层项目 2</div></div><div class="item">外层项目 1</div>
</div>
.outer-container {display: flex; /* 外层弹性容器 */
}.inner-container {display: flex; /* 内层弹性容器 */flex-direction: column; /* 垂直排列 */
}

通过在容器内嵌套另一个弹性容器,我们可以得到更复杂的布局。


十二、跨浏览器兼容性

Flexbox 在现代浏览器中得到了良好的支持,但在某些老旧浏览器(如 IE 10 和更早的版本)中可能会遇到问题。以下是一些提供跨浏览器兼容性的建议:

使用浏览器前缀:在开发需要兼容旧版浏览器的应用时,可以使用浏览器前缀(如 ​​-ms-​​、​​-webkit-​​)来确保 Flexbox 特性正常工作。

利用 CSS 重置或前缀库:可以使用像 Autoprefixer 这样的工具自动添加所需的前缀。


为帮助读者巩固所学知识,以下是两个综合练习题。

题 1:

创建一个弹性容器,其中包含 5 个项,要求如下:

  • 容器为水平排列,项之间的间距均等。
  • 项的宽度动态变化,第一个项占两倍的宽度。

代码示例

<div class="flex-container"><div class="flex-item">项 1</div><div class="flex-item">项 2</div><div class="flex-item">项 3</div><div class="flex-item">项 4</div><div class="flex-item">项 5</div>
</div>
.flex-container {display: flex; /* 弹性盒子 */justify-content: space-between; /* 项之间均等间距 */
}.flex-item {background: #4CAF50;color: white;padding: 15px;flex: 1; /* 默认宽度相同 */
}.flex-item:nth-child(1) {flex: 2; /* 第一个项宽度为两倍 */
}

题 2:

创建一个嵌套的弹性盒子布局,其中外层容器水平排列,内层容器垂直排列,内外层项目均需居中对齐。

代码示例

<div class="outer-container"><div class="inner-container"><div class="inner-item">内层项目 1</div><div class="inner-item">内层项目 2</div></div><div class="outer-item">外层项目 1</div>
</div>
.outer-container {display: flex; /* 外层为弹性盒子 */justify-content: center; /* 水平居中对齐 */align-items: center; /* 垂直居中对齐 */
}.inner-container {display: flex; /* 内层为弹性盒子 */flex-direction: column; /* 垂直排列 */justify-content: center; /* 垂直居中 */
}.inner-item, .outer-item {background: #4CAF50;color: white;padding: 15px; 
}

如有表述错误及欠缺之处敬请指正补充。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

提高开发效率的实用工具库VueUse

VueUse中文网&#xff1a;https://vueuse.nodejs.cn/ 使用方法 安装依赖包 npm i vueuse/core单页面使用&#xff08;useThrottleFn举例&#xff09; import { useThrottleFn } from "vueuse/core"; // 表单提交 const handleSubmit useThrottleFn(() > {// 具…

策略模式的小记

策略模式 策略模式支付系统【场景再现】硬编码完成不同的支付策略使用策略模式&#xff0c;对比不同&#xff08;1&#xff09;支付策略接口&#xff08;2&#xff09;具体的支付策略类&#xff08;3&#xff09;上下文&#xff08;4&#xff09;客户端&#xff08;5&#xff0…

python 交互模式怎么切换目录

假如要用交互界面调用一个.py文件&#xff1a; &#xff08;1&#xff09;用cmd界面定位到文件位置&#xff0c;如cd Desktop/data/ #进入desktop下data目录。 &#xff08;2&#xff09;接着打开python&#xff08;输入python&#xff09; 调用os &#xff08;1&#xff0…

Linux df命令详解,Linux查看磁盘使用情况

《网络安全自学教程》 df 一、字段解释二、显示单位三、汇总显示四、指定目录五、指定显示字段六、du和df结果不一样 df&#xff08;disk free&#xff09;命令用来查看系统磁盘空间使用情况。 参数&#xff1a; -h&#xff1a;&#xff08;可读性&#xff09;显示单位&#…

Mobile-Agent赛题分析和代码解读笔记(DataWhale AI夏令营)

前言 你好&#xff0c;我是GISer Liu&#xff0c;一名热爱AI技术的GIS开发者&#xff0c;本文是DataWhale 2024 AI夏令营的最后一期——Mobile-Agent赛道&#xff0c;关于赛题分析和代码解读的学习文档总结&#xff1b;这边作者也会分享自己的思路&#xff1b; 本文是对原视频的…

万象奥科参展“2024 STM32全国巡回研讨会”—深圳站、广州站

9月3日-9月5日&#xff0c;万象奥科参展“2024 STM32全国巡回研讨会”— 深圳站、广州站。此次STM32研讨会将会走进全国11个城市&#xff0c;展示STM32在智能工业、无线连接、边缘人工智能、安全、图形用户界面等领域的产品解决方案及多样化应用实例&#xff0c;深入解读最新的…

指针之旅(3)—— 指针 与 数组

目录 1. 数组名的两种意义 2. 指针访问数组&#xff08;指针也能下标引用&#xff09; 3. 一维数组传参的本质 和 sizeof在函数中失效的原因 4. 指针数组 4.1 指针数组的概念 4.2 一级指针数组 4.3 一级指针数组模拟实现二维数组 5. 数组、指针 与 字符串 6. 数组指针…

微信小程序接入客服功能

前言 用户可使用小程序客服消息功能&#xff0c;与小程序的客服人员进行沟通。客服功能主要用于在小程序内 用户与客服直接沟通用&#xff0c;本篇介绍客服功能的基础开发以及进阶功能的使用&#xff0c;另外介绍多种客服的对接方式。 更多介绍请查看客服消息使用指南 客服视…

多头切片的关键:Model 类 call解释;LlamaModel 类 call解释;多头切片的关键:cache的数据拼接

目录 Model 类 call解释 LlamaModel 类 call解释 方法签名 方法体 总结 Model 类 call解释 这段代码定义了一个特殊的方法 __call__,它是Python中的一个魔术方法(magic method),允许类的实例像函数那样被调用。在这个上下文中,这个方法很可能被定义在一个封装了某种…

【2025】公司仓库管理系统的设计与实现(公司仓库信息管理系统,仓库信息系统,管理系统,信息管理系统,货物仓管系统)

博主介绍&#xff1a; ✌我是阿龙&#xff0c;一名专注于Java技术领域的程序员&#xff0c;全网拥有10W粉丝。作为CSDN特邀作者、博客专家、新星计划导师&#xff0c;我在计算机毕业设计开发方面积累了丰富的经验。同时&#xff0c;我也是掘金、华为云、阿里云、InfoQ等平台…

【BIO、NIO、AIO适用场景分析】

BIO、NIO、AIO适用场景分析 1.适用场景&#xff1a;2.BIO基本介绍2.1 BIO示例 3.Java NIO基本介绍3.1 NIO中三个核心部分&#xff1a;3.2 NIO非阻塞3.3 buffer案例3.4 比较 1.适用场景&#xff1a; BIO方式适用于连接数目比较少且固定的架构&#xff0c;这种方式对服务器资源要…

Java对象拷贝的浅与深:如何选择?

在日常开发中&#xff0c;我们经常需要将一个对象的属性复制到另一个对象中。无论是使用第三方工具类还是自己手动实现&#xff0c;都会涉及到浅拷贝和深拷贝的问题。本文将深入讨论浅拷贝的潜在风险&#xff0c;并给出几种实现深拷贝的方式&#xff0c;帮助大家避免潜在的坑。…

gin 通过 OpenTelemetry 实现链路追踪

相关阅读:https://juejin.cn/post/7275550548946337829https://juejin.cn/post/7275550548946337829 OpenTelemetry 是 Cloud Native Computing Foundation (CNCF) 下的一个开源项目,旨在标准化遥测数据的生成和收集;遥测数据包括日志、指标和跟踪。 Gin 是一个用 Go (Gol…

69页PPT全面预算管理体系的框架与落地

一、明确企业战略目标企业战略目标是预算指标体系确立的根本出发点。它为预算指标的设定提供了方向和指导。 深入分析企业长期发展规划 企业需要对自身的长期发展规划进行全面、深入的分析。这包括对市场趋势、行业竞争态势、技术发展方向等外部环境因素的研究&#xff0c;以…

从API到应用:直播美颜SDK如何助力主播美颜工具开发

美颜SDK&#xff08;软件开发工具包&#xff09;作为一套强大的工具&#xff0c;能够帮助开发者快速构建美颜功能。通过集成API&#xff0c;开发者可以实现复杂的实时美颜效果&#xff0c;助力主播美颜工具的开发和应用。 一、美颜SDK的基本功能 美颜SDK是一套为开发者提供的…

【2024高教社杯全国大学生数学建模竞赛】B题模型建立求解

目录 1问题重述1.1问题背景1.2研究意义1.3具体问题 2总体分析3模型假设4符号说明&#xff08;等四问全部更新完再写&#xff09;5模型的建立与求解5.1问题一模型的建立与求解5.1.1问题的具体分析5.1.2模型的准备 目前B题第一问的详细求解过程以及对应论文部分已经完成&#xff…

中国生态环境胁迫数据(栅格/县域尺度)-为研究生态环境压力提供数据支撑

中国生态环境胁迫矢量数据&#xff08;2000-2010年&#xff09; 数据介绍 2000-2010年中国生态环境胁迫数据为2000-2010年中国范围内人口、农业生产等生态环境胁迫因子的空间分布图&#xff0c;包括人口密度、农药使用强度、化肥施用强度。数据可用于分析全国生态环境胁迫因子…

QT笔记 - QProcess读取外部程序(进程)消息

简要介绍 QProcess可用于在当前程序中启动独立的外部程序(进程)&#xff0c;并进行通讯&#xff0c;通讯原理是通过程序的输入或输出流&#xff0c;即通过c中的printf()和或c的std::cout等。 函数 void QProcess::start(const QString & program, const QStringList &am…

系统分析师7:数学与经济管理

文章目录 1 图论应用1.1 最小生成树1.2 最短路径1.3 网络与最大流量 2 运筹方法2.1 线性规划2.2 动态规划2.2.1 供需平衡问题2.2.2 任务指派问题 3 预测与决策3.1 不确定型决策分析3.2 风险型决策3.2.1 决策树3.2.2 决策表 4 随机函数5 数学建模 1 图论应用 ①最小生成树 连接…

Android 存储之 SharedPreferences 框架体系编码模板

一、SharedPreferences 框架体系 1、SharedPreferences 基本介绍 SharedPreferences 是 Android 的一个轻量级存储工具&#xff0c;它采用 key - value 的键值对方式进行存储 它允许保存和读取应用中的基本数据类型&#xff0c;例如&#xff0c;String、int、float、boolean …