【CSS】文本溢出省略的两种方式

【CSS】文本溢出省略的两种方式

假设有一个卡片组件,组件里的内容有长有短,我们希望在内容很长的时候省略文字,以保证卡片的高度不会过高。

单行文本

要实现在文字超出时不显示超出部分,并用省略号表示还有更多文字,需要使用 CSStext-overflow、white-space overflow 属性。

完整的 .content css:

css 复制代码
.content {
    max-height: 500px;
    margin-bottom: 8px;
    word-break: break-all;
    display: block;
    overflow: hidden; /* 确保内容超出时隐藏 */
    font-weight: 500;
    font-size: 14px;
    line-height: 140%;
    padding: 5px;
    color: #333;
    margin-bottom: 100px;

    /* 新增以下属性 */
    text-overflow: ellipsis; /* 超出部分显示为省略号 */
    white-space: nowrap; /* 保持内容在一行显示,如果需要多行,可以移除这行 */
}

这段代码中,overflow: hidden; 保证了内容超出部分会被隐藏,而 text-overflow: ellipsis; 则会在超出部分的末尾添加省略号。

然而,这段代码仅对单行文本起作用,在我们这个例子中,他是没有用的。

多行文本

使用 -webkit-line-clamp

最简单的方法是使用非标准的 -webkit-line-clamp 属性,它在大多数现代浏览器中都得到了支持。这个属性允许您指定显示的行数,并在超出这个行数时显示省略号。但请注意,这是一个非标准的、只在 WebKit/Blink 引擎(如 Chrome、Safari、新版 Edge)中有效的属性。

css 复制代码
.content {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3; /* 指定显示的行数 */
    overflow: hidden;
    text-overflow: ellipsis;
    max-height: 500px;
    margin-bottom: 8px;
    word-break: break-all;
    font-weight: 500;
    font-size: 14px;
    line-height: 140%;
    padding: 5px;
    color: #333;
    margin-bottom: 100px;
}

这段代码将 .content 的内容限制为显示三行,并在第三行末尾显示省略号。

总结

如果您的用户群体主要使用支持 -webkit-line-clamp 的浏览器,那么这是一个简单有效的解决方案。但如果您需要一个更通用的解决方案,可能就需要使用 JavaScript 来实现。每种方法都有其优点和局限性,您需要根据项目的具体需求来选择合适的实现方式。

相关推荐
相闻秋歌5 分钟前
四、Chrome调试工具
css·html5
GDAL6 分钟前
HTML 实现登录状态记录 深入全面讲解教程
前端·html·登录验证
(づど)8 分钟前
一套齐全的环境设置:nvm\node\nrm\pnpm
前端·笔记
晷龙烬11 分钟前
Vue 3 自定义指令:从“瑞士军刀”到“专属工具” !
前端·javascript·vue.js
MediaTea12 分钟前
思考与练习(第四章 程序组成与输入输出)
java·linux·服务器·前端·javascript
BD_Marathon14 分钟前
【JavaWeb】NPM_简介和相关配置
前端·npm·node.js
咸鱼加辣17 分钟前
【前端框架】react
前端·react.js·前端框架
unicrom_深圳市由你创科技18 分钟前
Vue 3 高效开发技巧总结
前端·javascript·vue.js
HIT_Weston20 分钟前
66、【Ubuntu】【Gitlab】拉出内网 Web 服务:Gitlab 配置审视(十)
前端·ubuntu·gitlab
长空任鸟飞_阿康24 分钟前
LangChain 技术栈全解析:从模型编排到 RAG 实战
前端·python·langchain