0

0

CSS3文字溢出怎么显示省略号_单行多行处理方法【技巧】

雪夜

雪夜

发布时间:2025-12-31 14:12:54

|

587人浏览过

|

来源于php中文网

原创

单行文字溢出显示省略号需同时设置 white-space: nowrap、overflow: hidden 和 text-overflow: ellipsis;多行则需 -webkit-box 相关属性及 max-height 配合,且 flex 场景下须加 min-width: 0。

css3文字溢出怎么显示省略号_单行多行处理方法【技巧】

单行文字溢出显示省略号必须同时设置三个 CSS 属性

只写 text-overflow: ellipsis 是没用的,浏览器根本不会触发省略逻辑。它只是“告诉浏览器:真要截断,就用省略号”,但前提是得先让文字真正溢出并被隐藏。

必须配合以下三者缺一不可:

  • white-space: nowrap —— 禁止换行,让文字强行保持单行
  • overflow: hidden —— 隐藏超出容器的部分
  • text-overflow: ellipsis —— 指定溢出时用省略号替代
div {
  width: 200px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

多行文字溢出加省略号不能只靠 text-overflow

text-overflow: ellipsis 原生只支持单行。想实现两行、三行甚至任意行数的截断+省略,得用 WebKit 私有属性 -webkit-line-clamp,且必须配合 Flex 或 Block 布局才能生效。

常见失效原因:忘了设 display: -webkit-box,或没配 -webkit-box-orient: vertical

立即学习前端免费学习笔记(深入)”;

p {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3; /* 显示 3 行 */
  overflow: hidden;
}

注意:-webkit-line-clamp 在 Firefox 和部分旧版 Edge 中不支持,如需兼容,得用 JS 计算行高 + 截断字符串,或服务端预处理。

HTTPie AI
HTTPie AI

AI API开发工具

下载

line-height 影响多行省略的准确性

当容器高度固定(比如 height: 60px),而 line-height: 24px,理论上最多容下 2 行(48px),但第 3 行可能因字体下沉或 padding 溢出一点点,导致 -webkit-line-clamp 渲染异常——要么多出半行,要么提前截断。

稳妥做法是:

  • max-height 替代 height,例如 max-height: calc(24px * 3)
  • 确保父容器没有 paddingborder 干扰行高计算
  • 字体尽量用无衬线体(如 system-ui),避免某些中文字体 baseline 不一致

Flex 容器里文字省略失效的典型场景

display: flex 的父容器中,子元素默认不收缩(flex-shrink: 1 但文字本身不受控),即使写了 text-overflow,也可能因为父容器没设 min-width: 0 或子项没设 flex: 1,导致宽度未被约束而撑开容器。

修复关键点:

  • 给需要省略的子元素加 min-width: 0(防止 flex item 默认最小宽度为内容宽)
  • 加上 flex: 1 或明确的 width,让宽度可被限制
  • 再叠加单行三件套或 -webkit-line-clamp

漏掉 min-width: 0 是最常被忽略的一环,尤其在卡片列表、表格单元格等 flex 场景中。

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

500

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

261

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

731

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

534

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

748

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

594

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

556

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

387

2023.08.22

小游戏4399大全
小游戏4399大全

4399小游戏免费秒玩大全来了!无需下载、即点即玩,涵盖动作、冒险、益智、射击、体育、双人等全品类热门小游戏。经典如《黄金矿工》《森林冰火人》《狂扁小朋友》一应俱全,每日更新最新H5游戏,支持电脑与手机跨端畅玩。访问4399小游戏中心,重温童年回忆,畅享轻松娱乐时光!官方入口安全绿色,无插件、无广告干扰,打开即玩,快乐秒达!

30

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.7万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.7万人学习

CSS教程
CSS教程

共754课时 | 17.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号