参考资料

  1. 多重选择器详细说明以及案例
  2. display: flex/inline-flex示例
  3. 属性选择器详细说明以及案例
  4. 伪元素选择器详细说明以及案例
  5. css阴影颜色怎么设置
  6. css3中设置阴影的属性是
  7. css阴影效果属性效果是什么
  8. 如何用Flex布局实现导航栏?
Flexbox 布局高级用法详解
一、多轴对齐与复杂排列

多轴对齐控制‌
通过 align-content 属性实现多行/列布局的交叉轴对齐(如 space-between、space-around),适用于多行弹性容器‌。
示例:.container { align-content: space-between; }

反向排列与动态换行‌
使用 flex-direction: row-reverse/column-reverse 反转主轴方向,或通过 flex-wrap: wrap-reverse 实现反向换行,适合特殊排版需求‌。
示例:.container { flex-flow: row-reverse wrap-reverse; }

二、动态空间分配与自适应

弹性项目伸缩规则‌
通过 flex-grow(扩展比例)、flex-shrink(收缩比例)、flex-basis(基准尺寸)精准控制项目空间占比,实现动态适配‌。
示例:.item { flex: 1 0 200px; }(基准200px,可扩展不收缩)

混合固定与弹性宽度‌
在容器中同时设置固定宽度和 flex-grow:1,实现部分元素固定、部分元素自动填充剩余空间‌。
示例:.item-static { width: 100px; } + .item-flex { flex-grow:1; }

三、特殊场景布局方案

嵌套Flex容器‌
在弹性项目内部嵌套新的Flex容器,形成多层弹性结构,适用于复杂组件(如导航栏内的子菜单)‌。
示例:

css
Copy Code
.container { display: flex; }
.item { display: flex; flex-direction: column; }


间距精准控制‌
使用 gap 属性统一设置项目间距(替代传统 margin),或通过 margin 实现非对称间距‌。
示例:.container { gap: 10px 20px; }(行间距10px,列间距20px)

四、进阶对齐技巧

独立项目对齐覆盖‌
通过 align-self 对单个项目设置特殊的交叉轴对齐方式(如 flex-end),打破容器全局对齐规则‌。
示例:.special-item { align-self: flex-end; }

主轴与交叉轴混合定位‌
结合 justify-content(主轴对齐)和 align-items(交叉轴对齐)实现复杂定位,如水平靠右+垂直居中‌。
示例:.container { justify-content: flex-end; align-items: center; }

五、实战优化建议
性能优化‌:避免过度嵌套Flex容器,优先使用简写属性 flex-flow(整合 flex-direction 和 flex-wrap)‌。
兼容性处理‌:针对旧版浏览器添加 -webkit- 前缀(如 display: -webkit-flex)‌。

通过灵活组合上述特性,可轻松实现卡片流、自适应表单、复杂导航等高级布局场景‌。