当前位置: 首页 > news >正文

弹性容器Flex中的自动外边距(Auto Margins) 的作用

最近在使用Flex布局时,遇到的一个情况:

有以下的代码:

    <div class="toolbox"><button id="decrease">-</button><span id="size">1</span><button id="increase">+</button><!-- 取色器 --><input type="color" id="color" /><button id="clear">X</button></div>

我们给父容器设置Flex布局,简单设置一下内部子元素的宽度和高度

      * {box-sizing: border-box;margin: 0;padding: 0;}.toolbox {display: flex;border: 1px solid lightcoral;width: 500px;}.toolbox > * {height: 50px;width: 50px;}

效果如下:
在这里插入图片描述
很简单的例子,但是如果我给最后一个子元素设置设置一下css代码 :

 .toolbox > *:last-child {margin-left: auto;}

效果变成了以下:
在这里插入图片描述
最后一个元素变成了右对齐,自动把剩余的空间全部变成了他的左外边距margin-left:
在这里插入图片描述
为什么会产生这种情况呢?
关于这个问题,我直接问了GPT3.5,它提到了一个叫做 自动外边距(Auto Margins),但是我并没有搜索到相关的资料,所以只能参考了GPT的回答,其中给出了W3C的候选规范:Aligning with auto margins

This section is non-normative. The normative definition of how margins affect flex items is in the Flex Layout Algorithm section.

Auto margins on flex items have an effect very similar to auto margins in block flow:

  • During calculations of flex bases and flexible lengths, auto margins
    are treated as 0.
  • Prior to alignment via justify-content and align-self, any positive
    free space is distributed to auto margins in that dimension.
  • Overflowing boxes ignore their auto margins and overflow in the end
    direction.

Note: If free space is distributed to auto margins, the alignment properties will have no effect in that dimension because the margins will have stolen all the free space left over after flexing.

在这里插入图片描述

nav > ul {display: flex;
}
nav > ul > #login {margin-left: auto;
}
<nav><ul><li><a href=/about>About</a><li><a href=/projects>Projects</a><li><a href=/interact>Interact</a><li id="login"><a href=/login>Login</a></ul>
</nav>

理解不太容易理解,只能说这就是规范,直接记住结论,关键点如下:
本例中的margin-left: auto;的效果是该方向的外边距尽可能大,直到填充主轴上的所有可用空间为止,在设置 margin-left: auto 的情况下,浏览器会为该元素的左侧自动分配剩余空间,结果是该元素会被推到容器的右侧。

然后副作用是:如果自动外边距吸收了所有可用空间,那么像 justify-content 这样的对齐属性在该维度上将不再有效,因为没有剩余空间来进行对齐。

所以,如果我们设置了父容器的justify-content: center;同时内部的子元素设置了 margin-left: auto ,此时justify-content: center;不生效:

      .toolbox {display: flex;/* justify-content: space-between; */justify-content: center;border: 1px solid lightcoral;width: 500px;}.toolbox > * {height: 50px;width: 50px;}.toolbox > *:nth-child(5) {margin-left: auto;}

效果如下,justify-content: center;不生效
在这里插入图片描述
根据这个效果,我们就可以在一些场景下应用这个,比如类似的导航栏效果:
在这里插入图片描述
实现类似效果还有其他方法,比如弹性盒子的嵌套,或者用定位,但是这种方式代码简单,同时也具备响应式。

另外如果我们修改代码为:

      .toolbox > *:nth-child(4) {margin-left: auto;}

第4个元素以及后面的兄弟元素会一起被左侧边距挤到右侧
在这里插入图片描述

http://www.lryc.cn/news/431637.html

相关文章:

  • C语言调用子函数时入/出栈(保护/恢复现场)全过程分析:以Cortex-M3为例
  • 理解Sigmoid激活函数原理和实现
  • 探秘DevSecOps黄金管道,安全与效率的完美融合
  • Redis的内存淘汰策略- volatile-lru
  • HTTP和HTTPS的区别?哪一个更适合你的网站?
  • OpenAI SORA团队负责人 通往智能的方式 报告笔记
  • 006-Sleuth(Micrometer)+ZipKin分布式链路追踪
  • AI模型:追求全能还是专精?-- 之6 语言复杂度类别(Category 0~3 类)和语言功能性类型(Type 0~Ⅲ 型)之2
  • 20240907 每日AI必读资讯
  • 深度学习基础--卷积基础模块
  • 视频智能分析打手机检测算法安防监控打手机检测算法应用场景、算法源码、算法模型介绍
  • 6.2图的存储及基本操作
  • Java语法全解析:掌握基本规则,打造稳固编程基础!
  • 同时播放多个视频
  • 伴奏提取消除人声如何操作?轻松几步玩转音乐世界
  • uniapp二维码生成
  • Android UID 和 userID 以及 appID
  • Kafka的三高设计原理
  • 生信圆桌x生信宝库:生物信息学资源与工具的终极指南
  • centos7 install rocketmq 宿主机快速搭建RocketMQ单机开发环境_centos7 单机部署rocketmq命令
  • 2024高教社杯全国大学生数学建模竞赛(A题)深度剖析 _ 建模完整过程+详细思路+代码全解析
  • What is Approximation Ratio?
  • 探索Unity与C#的无限潜能:从新手到高手的编程之旅
  • 初始MYSQL数据库(2)——创建、查询、更新、删除数据表的相关操作
  • OpenCV直方图计算
  • 多线程篇(并发相关类- 原子操作类)(持续更新迭代)
  • 数学建模常用工具总结
  • 【Redis】为什么选择 Redis 做缓存?
  • Flutter 开发常用第三方库总结
  • OpenCV中的颜色映射函数applyColorMap的使用