flex 布局快速梳理

flex 布局快速梳理

属性

  • flex-direction: 定义主轴的方向

    1. row
    2. row-reverse
    3. column
    4. column-reverse
  • justify-content: 定义主轴上的对齐方式

    1. flex-start
    2. flex-end(这两个可以做聊天对话的布局)
    3. center
    4. space-between(第一个和最后一个紧贴容器边缘)
    5. space-around
    6. space-evenly(解决前一个中间间隙是两边间隙两倍的问题)
  • align-items: 定义交叉轴上的对齐方式

    1. flex-start
    2. flex-end
    3. center
  • gap: 虽然不是 flex 的属性,但可以用来设置子元素之间的间距, 在flex布局中好用

  • flex-wrap: 定义是否换行

    1. nowrap(当父盒子空间不足时, 子盒子会收缩)
    2. wrap
    3. wrap-reverse
  • align-content: 定义多行时的对齐方式

    当 flex-wrap: wrap 时, 如果有多行, 就相当于每一行有一个主轴和交叉轴, align-items 只是定义了对应一行交叉轴的对齐方式

    1. flex-start
    2. flex-end
    3. center
    4. space-between
    5. space-around
    6. space-evenly
    7. stretch(默认值, 每行占满交叉轴剩余空间, 所以显的每行间距很大)

定义在子项目上的属性

  • flex-shrink: 定义子项目的收缩比例, 默认值为 1, 如果父盒子空间不足, 就会按照这个比例来收缩, 如果设置为 0, 就不会收缩

  • flex-grow:定义子项目的放大比例, 默认值为 0, 如果父盒子空间充足, 就会按照这个比例来放大, 如果设置为 1, 就会放大到占满父盒子剩余空间

以上他们可以和max-width和max-height配合使用, 来限制子项目的最大尺寸, 以防止它们过度放大或收缩, 且他们的值是一种权重, 表示"速率"

结合媒体查询来防止元素溢出, 当设置 min-width 或 min-height 时, 可以确保元素不会缩小到一定程度以下, 从而避免内容溢出或布局崩溃

css 复制代码
@media screen and (max-width: 600px) {
    .container {
        flex-wrap: wrap;
    }
}
  • align-self: 定义子项目在交叉轴上的对齐方式, 可以覆盖父项目的 align-items 属性

    1. auto(默认值, 继承父项目的 align-items 属性)
    2. flex-start
    3. flex-end
    4. center
    5. baseline(与父项目的基线对齐)
    6. stretch(占满交叉轴剩余空间)

示例

导航栏

一个元素在最左侧, 其他元素在最右侧

css 复制代码
.container {
    display: flex;
    justify-content: flex-end;
}

#item1 {
    margin-right: auto;
}

总结

相关推荐
swipe1 小时前
Mem0 x Agent 实战系列:分层记忆 + 三路召回,搭建真正可用的长期记忆层
前端·javascript·面试
天天进步20151 小时前
Python全栈项目--校园智能宿舍管理系统
开发语言·python
CodeStats1 小时前
从 CPU 指令到 JVM 进程:彻底讲透 Java 执行 main 方法时,类加载、主线程、栈帧入栈的完整底层逻辑
java·linux·开发语言
kyriewen1 小时前
手写 call、apply、bind:从原理到实现,附 3 个最容易忽略的边界情况
前端·javascript·面试
胡萝卜术2 小时前
从内存视角重新认识 JavaScript 数据类型:一份深度学习笔记
前端·javascript·面试
阿正的梦工坊2 小时前
【Rust】09-泛型、Trait 与生命周期基础
开发语言·rust·c#
阿正的梦工坊2 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
LiuJun2Son2 小时前
Angular 快速入门:从零搭建你的第一个应用
前端·javascript·angular.js