实现:每行固定 5 个、自动换行、最后一行左对齐、数量不固定

1、Flex 布局实现:每行 5 个,最后一行左对齐(删除 justify-content: space-around,使用 width: calc(20% - 8px) + gap 实现每行 5 个,最后一行自然左对齐)

javascript 复制代码
<template>
    <div class="flex-container">
    <div class="flex-item">1</div>
    <div class="flex-item">2</div>
    <div class="flex-item">3</div>
    <div class="flex-item">4</div>
    <div class="flex-item">5</div>
    <div class="flex-item">6</div>
    <div class="flex-item">7</div>
    <div class="flex-item">8</div>
    <div class="flex-item">9</div>
    <div class="flex-item">10</div>
    <div class="flex-item">11</div>
    <div class="flex-item">12</div>
    <div class="flex-item">13</div>
  </div>
</template>

<script>

</script>

<style lang="less" scoped>
   /* 父容器:核心 flex 配置 */
    .flex-container {
      display: flex;
      flex-wrap: wrap; /* 自动换行 */
      gap: 10px; /* 盒子之间的间距(可修改) */
    }

    /* 子盒子:固定每行5个 */
    .flex-item {
      /* 核心公式:(100% - 4个间距) / 5 */
      width: calc(20% - 8px); 
      height: 80px;
      background: #409eff;
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      box-sizing: border-box;
    }
</style>

2、如果项目里必须保留 justify-content: space-around,可以用伪元素填充

html 复制代码
.flex-container::after {
  content: "";
  flex: auto;
  max-width: calc(20% - 10px);
}

3、Grid 网格布局(最推荐,最简单)

Grid 天生就是做多列等宽网格不用算百分比、不用处理间距 ,直接定义 5列,自动换行,最后一行天然左对齐,完全没有 flex space-around 最后一行散开的问题

html 复制代码
.container {
  display: grid;
  grid-template-columns: repeat(5, 1fr); /* 固定5列,均分宽度 */
  gap: 10px; /* 间距 */
}
.item {
  height: 80px;
  background: #409eff;
}

4、传统 Float 浮动布局(兼容老项目)

最老的方案,IE 也能用,每行 5 个,自动换行,最后一行天然左对齐。缺点:需要清除浮动。

复制代码
.container::after { /* 清除浮动 */
  content: "";
  display: block;
  clear: both;
}
.item {
  float: left;
  width: calc(20% - 8px);
  margin: 0 4px 10px;
  height: 80px;
  background: #409eff;
}
相关推荐
竹林818几秒前
用 wagmi v2 踩坑两天,我终于搞懂了多链钱包切换在 DeFi 前端中的正确姿势
前端·javascript
用户2136610035723 分钟前
Vue项目搜索功能与面包屑导航
前端·javascript
星栈7 分钟前
LiveView 的实时通信,爽是爽,但 PubSub 和广播也最容易把自己绕晕
前端·前端框架·elixir
用户2930750976698 分钟前
告别关键词匹配,拥抱向量语义 —— RAG 搜索从零到一
前端
独孤留白17 分钟前
从C到Rust:告别 C 的"指针 + 长度"手动模式
前端·rust
阿黎梨梨30 分钟前
揭秘大语言模型的底层逻辑:从文本分词到高维向量的计算之旅
javascript·人工智能
掘金安东尼1 小时前
中小厂前端候选人简历面试拆解:从 HR 面、技术面到主管面的双赢提问法
前端·面试
天平10 小时前
油猴脚本创建webworker踩坑记录
前端·javascript·typescript
原则猫11 小时前
前端基础大厦
前端