Flexbox – 对齐和分配空间的现代方式
来源:dev.to
时间:2024-09-20 20:45:57 125浏览 收藏
欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《Flexbox – 对齐和分配空间的现代方式》,这篇文章主要讲到等等知识,如果你对文章相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!
第 14 讲:flexbox – 对齐和分配空间的现代方式
嘿那里!准备好深入研究 css 中最酷、最强大的工具之一了吗?今天,我们将探索 flexbox。如果您曾经在以简洁且响应迅速的方式对齐项目或分配空间方面遇到困难,那么 flexbox 是您最好的新朋友。
1.什么是 flexbox?
flexbox(灵活框布局)是一种一维布局系统,允许您控制容器内元素的对齐、间距和分布 - 即使这些元素的大小未知或动态。
将 flexbox 视为一个工具箱,用于创建可以根据可用空间拉伸、收缩或对齐的布局。
2.魔法从显示开始:flex
要开始使用 flexbox,您只需在容器上设置 display: flex 即可。一旦你这样做了,该容器的所有直接子代都会变成弹性项目,并且它们将立即开始表现不同。
item 1item 2item 3
.flex-container { display: flex; }
现在,.flex-container 中的所有项目都是 flex 项目,可以轻松操作。
3.弯曲方向 – 我们应该走哪条路?
默认情况下,flexbox 将项目排列成行(水平),但如果您希望它们排列成列(垂直)怎么办? flexbox 通过 flex-direction 属性为您提供完全控制。
- 行:在水平行中对齐项目(这是默认值)。
- 列:将项目堆叠在垂直列中。
- row-reverse:与 row 相同,但项目的顺序相反。
- column-reverse:与column相同,但项目以相反的顺序堆叠。
.flex-container { display: flex; flex-direction: column; }
现在,物品将垂直堆叠!
4.证明内容合理性 – 传播事物
假设您有三件物品,并且您想将它们均匀地分布在容器中。这就是 justify-content 派上用场的地方。
- flex-start:项目与容器的开头对齐(默认)。
- center:项目居中。
- space- between:项目均匀分布,第一个项目在开始,最后一个项目在结束。
- space-around:项目在每个项目周围以相等的填充间隔。
.flex-container { display: flex; justify-content: space-between; }
现在,物品将在容器内均匀分布。
5.对齐项目 – 垂直魔法
justify-content 控制水平对齐,而 align-items 负责垂直对齐(或沿横轴)。以下是您的选择:
- 拉伸:项目拉伸以填充容器(默认)。
- flex-start:项目与顶部对齐。
- flex-end:项目与底部对齐。
- center:项目垂直居中。
.flex-container { display: flex; align-items: center; }
现在,所有项目都将在容器内垂直居中。
6. flex-grow、flex-shrink 和 flex-basis – 微调 flex 项目
有时,您希望某些项目增大、缩小或具有固定的起始尺寸。 flex-grow、flex-shrink 和 flex-basis 属性可让您控制该行为:
- flex-grow:控制一个项目相对于其他项目应该增长多少。
- flex-shrink:控制一个项目相对于其他项目应收缩的程度。
- flex-basis:设置项目在增大或缩小之前的初始大小。
示例:
.item { flex-grow: 1; flex-shrink: 0; flex-basis: 100px; }
这可确保项目从 100 像素开始,但如果需要,它可以增长以填充额外的空间,而不会缩小。
7.实践中的 flexbox 示例
让我们用一个例子将所有这些放在一起!
item 1item 2item 3
.flex-container { display: flex; flex-direction: row; justify-content: space-around; align-items: center; height: 300px; background-color: #f0f0f0; } .item { background-color: #4CAF50; padding: 20px; color: white; flex-grow: 1; }
在此示例中:
- 项目排列成行。
- 它们通过 justify-content: space-around 均匀分布。
- 所有项目都在容器中垂直居中,并使用align-items: center。
- 由于 flex-grow,每个项目都会增长以均匀地填充可用空间:1.
8.为什么 flexbox 如此受欢迎
flexbox 消除了我们过去在 css 中遇到的布局设计的复杂性。不再有浮动,不再担心清理,响应式设计变得更加简单!
要点:
- 使用 display: flex 将容器变成 flex 容器。
- 使用flex-direction设置流向(行或列)。
- 使用 justify-content 和 align-items 来控制间距和对齐。
- 使用 flex-grow、flex-shrink 和 flex-basis 微调您的弹性项目。
在 linkedin 上关注我-
里多伊·哈桑
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Flexbox – 对齐和分配空间的现代方式》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
420 收藏
-
472 收藏
-
230 收藏
-
346 收藏
-
217 收藏
-
307 收藏
-
269 收藏
-
141 收藏
-
343 收藏
-
492 收藏
-
343 收藏
-
216 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习