news 2026/6/9 20:52:20

[flex排版]HTML Learn Data Day 6

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[flex排版]HTML Learn Data Day 6

稍微把js中的dom看了一下,感觉大部分是由于历史包袱导致的繁琐 API,现阶段不需要死记硬背,用到时查阅即可。

不想去背,把其他的知识看了一下。于是转头回来学css

今天稍微看了一下flex相关内容,由于浮动不被建议学,所以浮动没有去看了

下一次就直接学vue3相关了

Flex 布局

Flex没什么特别深奥的,它非常像 Qt 中的Spacer(弹簧) 或 Layout 系统

Flex 专为模块化的网页布局而生,能轻松地将网页划分为一个个区块,并自动处理排版,告别了手动计算长宽占比的痛苦时代。

1. 核心概念:轴向 (Axis)

Flex 布局主要由两个轴决定:主轴 (Main Axis)侧轴 (Cross Axis)

  • 主轴:默认为横向(row),即从左到右。
  • 侧轴:与主轴垂直,默认为纵向,即从上到下。

默认行为注意:

  • 主轴尺寸:在未设置具体宽度时,主轴方向的长度默认由内容撑开。
  • 侧轴尺寸:在未设置具体高度时,子元素默认会在侧轴方向拉伸填满(前提是align-itemsstretch且子元素没有写死高度)。

2. 父容器属性 (Container Properties)

根据代码实践,整理了常用的 Flex 容器属性:

属性作用**常见取值 **
display开启 Flex 布局flex
justify-content主轴方向的排列方式flex-start(左/上)center(居中)space-between(两端对齐,中间留空)space-around(每个元素周围分配空间)
align-items侧轴方向的单行对齐方式stretch(默认,拉伸)center(居中)flex-end(底部对齐,防止拉伸)
flex-wrap控制子元素是否换行nowrap(默认,不换行,强行挤压)wrap(换行,多行显示)
align-content侧轴方向的多行对齐方式(仅在flex-wrap: wrap时生效)space-between(多行之间拉开)center(多行整体居中)flex-start(多行紧贴顶部)

3. 子元素属性 (Item Properties)

Flex 不仅控制容器,还能控制子元素如何分配空间(这才是“弹簧”的精髓):

  • flex 属性:

    这是 flex-grow、flex-shrink 和 flex-basis 的简写。

    • flex: 1;:表示该子元素占用父容器的剩余空间的 1 份。
    • 如果所有子元素都设为flex: 1,则它们平分剩余空间。
    • 如果一个设为flex: 1,另一个设为flex: 3,则后者占据的空间是前者的 3 倍。

4. 实战代码演示

结合 HTML 练习代码的总结:

CSS

.box { display: flex; /* 1. 主轴对齐:两端对齐,中间留空 */ justify-content: space-between; /* 2. 允许换行:一行放不下时自动折行 */ flex-wrap: wrap; /* 3. 多行侧轴对齐:行与行之间两端对齐 */ align-content: space-between; /* 4. 单行侧轴对齐:如果子元素写死了高度,需注意该属性 */ /* align-items: flex-end; */ width: 500px; height: 400px; background-color: pink; border: 2px solid; } .box div { /* 子元素如果有固定宽高,就不会被默认拉伸,除非 align-items 强制拉伸 */ width: 100px; height: 100px; border: 1px solid; } /* 进阶:单独控制某个子元素的“弹簧”系数 */ /* .box div:nth-child(2) { flex: 1; // 自动吸收剩余空间 } */

总结

Flex 布局的核心在于“轴”的概念以及“剩余空间”的分配。只要搞清楚主轴是横还是竖,剩下的就是用justifyalign来指挥元素往哪里靠。

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

生态保护项目引入GLM-4.6V-Flash-WEB评估恢复成效

生态保护项目引入GLM-4.6V-Flash-WEB评估恢复成效 在一片刚刚完成退耕还林的山地,护林员举起手机拍下一张航拍图,上传到网页平台,输入问题:“当前植被覆盖情况如何?是否有裸露土壤或破坏痕迹?”不到30秒&am…

作者头像 李华
网站建设 2026/6/8 3:43:44

B站视频转文字实战指南:三步搞定高效内容提取

B站视频转文字实战指南:三步搞定高效内容提取 【免费下载链接】bili2text Bilibili视频转文字,一步到位,输入链接即可使用 项目地址: https://gitcode.com/gh_mirrors/bi/bili2text 还在为整理B站视频内容而反复暂停播放吗&#xff1f…

作者头像 李华
网站建设 2026/6/9 19:42:09

用AI打造智能斗鱼养殖监测系统

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个斗鱼智能养殖监测系统,使用传感器监测水温、PH值和溶氧量,通过AI分析数据并自动调节。系统需包含实时数据展示面板、异常报警功能和历史数据记录。…

作者头像 李华
网站建设 2026/6/6 16:19:36

从零搭建企业级云记事本:快马平台实战指南

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个企业级云记事本系统,功能包括:1. 用户注册/登录(支持OAuth) 2. 富文本编辑器(支持图片上传) 3. 多设备实时同步 4. 团队协作(多人同时编辑) 5. 版本…

作者头像 李华
网站建设 2026/6/5 15:38:39

企业级TOMCAT8实战:从下载到高可用集群部署

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 开发一个TOMCAT8企业部署向导,功能包括:1.不同场景下的版本选择建议 2.性能调优参数生成器 3.集群配置模板 4.健康检查脚本 5.日志分析工具集成。要求使用D…

作者头像 李华
网站建设 2026/6/5 14:54:34

用AI自动生成CompletableFuture代码,提升异步开发效率

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容: 创建一个Java项目,使用CompletableFuture实现以下功能:1) 异步调用三个不同的REST API获取数据;2) 合并三个API的返回结果;3) 处理可…

作者头像 李华