Flex 布局下文字省略不生效?原因其实很简单

作者:序猿杂谈日期:2025/10/8

概述

flex_layout_ellipsis.png

在开发中,我们常遇到这种布局:A、B、C 三段文本长度不固定,其中 A、C 占用空间较少,需要完整显示;而 B 是自适应区域,超出部分需省略显示。A 与 B 共享同一容器,右侧的 “Live” 按钮与该容器同级,容器应占据除 “Live” 之外的所有剩余空间。

HTML 结构如下:

1<div class="wrap">
2  <div class="infos">
3    <div>Soccer</div>
4    <div class="self">Campeonato De Reserva De Primera Division C</div>
5  </div>
6  <div class="live">Live</div>
7</div>
8

如果按照常规思路编写 CSS,比如:

1.wrap {
2  display: flex;
3  align-items: center;
4  width: 350px;
5  border: 1px dashed #ccc;
6  padding: 4px 16px;
7  gap: 16px;
8}
9
10.infos {
11  flex: 1;
12  display: flex;
13  gap: 8px;
14  align-items: center;
15}
16
17.self {
18  flex: 1;
19  padding: 4px;
20  background-color: silver;
21  border-radius: 6px;
22  overflow: hidden;
23  white-space: nowrap;
24  text-overflow: ellipsis;
25}
26
27.live {
28  padding: 4px 16px;
29  background: cornflowerblue;
30  border-radius: 6px;
31  color: white;
32  flex-shrink: 0;
33}
34
35

渲染效果往往会出现问题,示例如下:

flex_layout_wrong.png

可以看到,.self 会被内容撑开,导致 “Live” 被挤出容器。

异常分析

出现这种情况的根本原因是:

在 Flex 布局中,每个子元素的默认 min-width 是 auto。这意味着子元素的内容(文本)不会被压缩,即使父容器空间不足。

只有显式将 min-width 设为 0,才能让子项在空间受限时被压缩,从而使 overflow: hidden 与 text-overflow: ellipsis 生效。

更关键的是:

如果布局中存在嵌套的 flex 容器,那么 所有中间层的容器 也需要显式设置 min-width: 0,否则内部文本依然不会被压缩。

本例结构如下:

1.wrap (display: flex)
2  ├── .infos (display: flex)
3  │     ├── div (Soccer)
4  │     └── .self (文字太长)
5  └── .live
6

.infos 是 .wrap 的 flex 子项,默认 min-width: auto,会阻止内部 .self 被压缩。

因此,.infos 和 .self 都必须加上 min-width: 0。

实现

1<!DOCTYPE html>
2<html lang="zh-CN">
3  <head>
4    <meta charset="UTF-8" />
5    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6    <title>Flex 布局下文字省略不生效?原因其实很简单</title>
7    <style>
8      * {
9        margin: 0;
10        padding: 0;
11      }
12      body {
13        width: 100vw;
14        height: 100vh;
15        display: flex;
16        justify-content: center;
17        align-items: center;
18      }
19      .wrap {
20        display: flex;
21        align-items: center;
22        width: 350px;
23        border: 1px dashed #ccc;
24        padding: 4px 16px;
25        gap: 16px;
26      }
27
28      .infos {
29        flex: 1;
30        display: flex;
31        gap: 8px;
32        align-items: center;
33        min-width: 0; /* ✅ 必加,让内部 .self 可以被压缩 */
34      }
35
36      .self {
37        flex: 1;
38        min-width: 0; /* ✅ 必加,否则 ellipsis 不生效 */
39        padding: 4px;
40        background-color: silver;
41        border-radius: 6px;
42        overflow: hidden;
43        white-space: nowrap;
44        text-overflow: ellipsis;
45      }
46
47      .live {
48        padding: 4px 16px;
49        background: cornflowerblue;
50        border-radius: 6px;
51        color: white;
52        flex-shrink: 0;
53      }
54    </style>
55  </head>
56  <body>
57    <div class="wrap">
58      <div class="infos">
59        <div>Soccer</div>
60        <div class="self">Campeonato De Reserva De Primera Division C</div>
61      </div>
62      <div class="live">Live</div>
63    </div>
64  </body>
65</html>
66
67

总结

层级是否需要 min-width: 0原因
.wrap最外层容器,不需要压缩
.infos它是 .wrap 的 flex 子项,需要允许内部压缩
.self它是 .infos 的 flex 子项,真正要被省略的元素

结论:在嵌套的 Flex 布局中,任何包裹文字的中间层都必须显式设置 min-width: 0,否则 text-overflow: ellipsis 永远不会生效。


Flex 布局下文字省略不生效?原因其实很简单》 是转载文章,点击查看原文


相关推荐


Python 的内置函数 bin
IMPYLH2025/10/6

Python 内建函数列表 > Python 的内置函数 bin bin()函数是Python内置的一个简单但强大的工具,它能够将整数转换为以"0b"为前缀的二进制字符串表示形式。在计算机科学中,二进制是基础中的基础,理解二进制表示对于学习位运算、硬件接口编程、数据压缩等领域都至关重要。 bin 的函数原型如下所示: def bin(x:int): ''' 将一个整数转换为带前缀 `0b` 的二进制字符串 :param x: 一个整数 :return: x


MySQL Exporter采集的关键指标有哪些,如何解读这些指标?
IT橘子皮2025/10/5

MySQL Exporter 是 Prometheus 生态中用于监控 MySQL 数据库的核心工具,通过采集丰富的性能指标帮助用户分析数据库运行状态。以下是其关键指标分类及解读方法: 一、核心指标分类与解读 1. ​数据库可用性与基础状态​ ​**mysql_up**​ 值为 1表示 MySQL 实例正常运行,0表示不可用。用于快速判断数据库是否存活。 ​**mysql_global_status_uptime**​ 数据库已运行时间(秒)。若突然归零可能表示实例重启,需结合告警规则


从技术史看:Unix 从何而来
大聪明-PLUS2025/10/4

大家好!我是大聪明-PLUS! 如今,许多人认为“Unix”和“Linux”是同一个东西。但从 2024 年起,对于大多数我们认为是“Unix”和“Linux”的发行版来说,情况基本如此。 但 Unix 的历史悠久。如果你只了解我们今天所熟知的 Linux 系统,很难想象“Unix 早期的情况是什么样的”,因为自那时以来发生了太多变化。 ❯ 从原型到 Unix 让我们回顾一下 Unix 的起源。1969 年,贝尔实验室的研究员 Ken Thompson 正在尝试操作系统设计。 当时,贝


笔记本 光驱 的内部结构及用法: 应急系统启动 (恢复) 光盘 (DVD+R/RW)
穷人小水滴2025/10/3

光盘 (CD/DVD/BD) 基本上是一种被淘汰的古老存储技术了, 然而在特定领域, 光盘仍然具有明显的使用价值, 宝刀未老. 低成本 (特别是单张光盘很便宜), 防水防磁耐摔, 只读 (不可修改, 比如 DVD+R, BD-R), 读写设备与存储分离, 这些优点至今难以超越. 笔记本光驱 (轻薄小, 9 ~ 13mm 厚) (二手) 淘宝价约 30 元/个, 5.25 英寸 SATA 大光驱 (台式) (二手) 淘宝价约 20 元/个, 单张光盘 (全新) 只需 2 元. 本文介绍目前还能用的


unzip-6.0-21.el7.x86_64.rpm怎么安装?CentOS 7手动安装rpm包详细步骤
心灵宝贝2025/10/2

本文介绍了如何在 ​CentOS 7​ 系统上手动安装 unzip-6.0-21.el7.x86_64.rpm 这个 RPM 包,包括下载后如何用终端命令进行安装、常见问题的解决方法,以及如何验证是否安装成功 一、确保你有这个 rpm 文件 首先,你电脑上得有这个文件,比如它叫: ​unzip-6.0-21.el7.x86_64.rpm​ 安装包下载:https://pan.quark.cn/s/34cd3075c0fd 二、打开终端(命令行) 在 Linux 系统里(比如 Ce


开源多场景问答社区论坛Apache Answer本地部署并发布至公网使用
秦禹辰2025/10/2

本篇文章介绍如何在本地部署问答软件 Apache Answer,并结合 Cpolar 内网穿透发布至公网。 Answer 是一个高可扩展的开源知识型社区软件,对标国内外知乎等平台,可以免费使用 Answer 高效地搭建一个问答平台,任何组织与个人都可以免费使用 Answer 高效地搭建问答社区,用于产品技术问答、客户支持、用户交流等场景,让组织与用户之间、用户与用户之间更友好地交流、学习和成长。 在 Answer 构建的知识问答社区里,用户可以通过贡献高质量的内容、接受答案以及获得用户投票和


ZooKeeper与Kafka分布式协调系统实战指南:从基础原理到集群部署
荣光波比10/2/2025

本文深入探讨了Apache ZooKeeper和Kafka两大分布式系统核心技术。ZooKeeper作为分布式协调服务,其核心机制包括观察者模式、ZNode数据结构和选举算法,可应用于统一命名、配置管理、集群监控等场景。文章详细解析了ZooKeeper的首次启动和非首次启动选举流程,并提供了完整的集群部署方案,包括环境准备、JDK安装和ZooKeeper配置步骤。通过层次化的数据模型和高效的协调机制,ZooKeeper为分布式系统提供了可靠的基础设施支持。


【Nginx系列】前端重定向
檀越@新空间9/30/2025

🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!指令来实现这个 URL 转换。使用 nginx 转为下面的请求。可以使用 nginx 的。


GitHub 热榜项目 - 日榜(2025-09-27)
CoderJia_9/30/2025

本期GitHub热榜持续聚焦AI应用生态,AI代理与RAG框架成为核心热点。Google Gemini生态全面爆发,终端集成(gemini-cli)和API应用(cookbook)占据头部,体现大模型向开发者工具链的深度渗透。RAG技术框架(RAG-Anything)和文档解析(Dolphin)推动检索增强生成落地。边缘AI部署(exo)和开源媒体系统(jellyfin)显示去中心化趋势。整体呈现AI工具平民化、性能优化(gin)与垂直场景深度结合的特征。


【LeetCode - 每日1题】水位上升的泳池中游泳问题
(时光煮雨)2025/10/9

🌈 个人主页:(时光煮雨) 🔥 高质量专栏:vulnhub靶机渗透测试 👈 希望得到您的订阅和支持~ 💡 创作高质量博文(平均质量分95+),分享更多关于网络安全、Python领域的优质内容!(希望得到您的关注~) 🌵目录🌵 难度 ⭐⭐⭐⭐⭐ 题目回顾 ✅解题思路分析 💖 概述 💓 核心思路 ✅ 代码分析 ✅ 复杂度分析 ✅ 测试用例验证 ✅

首页编辑器站点地图

Copyright © 2025 聚合阅读

License: CC BY-SA 4.0