文本溢出体验进阶:CSS 技巧实现单行/多行隐藏展示以及实际场景应用,确保内容可读性和布局整洁性

本文主要是介绍文本溢出体验进阶:CSS 技巧实现单行/多行隐藏展示以及实际场景应用,确保内容可读性和布局整洁性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

CSS文本溢出隐藏是一种常见的场景,它广泛应用于各种网页设计中,旨在确保内容的可读性和布局的整洁性,特别是在空间有限或需要适应不同屏幕尺寸的情况下。

一、文本溢出隐藏并显示省略号

1、单行文本溢出隐藏并显示省略号

对于单行文本,通常只需设置以下三个CSS属性:

.single-line-text {overflow: hidden; /* 隐藏溢出内容 */text-overflow: ellipsis; /* 当文本溢出时显示省略号 */white-space: nowrap; /* 禁止文本换行 */
}

应用示例:

<div class="single-line-text">这是一段非常非常非常非常非常非常长的单行文本,超出部分会被隐藏并显示省略号...
</div>

在这个例子中,当文本长度超过其容器的宽度时,超出的部分将会被隐藏,同时在文本末尾显示省略号(…),表示文本已被截断。

2、多行文本溢出隐藏并显示省略号

多行文本的溢出隐藏并显示省略号稍微复杂一些,因为CSS标准本身并不直接支持多行文本的text-overflow: ellipsis。不过,可以通过结合使用line-clamp属性(现代浏览器支持)和伪元素来模拟这一效果:

.multi-line-text {display: -webkit-box; /* 兼容WebKit内核浏览器,如Chrome和Safari */-webkit-line-clamp: 3; /* 显示最大3行 */-webkit-box-orient: vertical; /* 设置垂直方向上的排列方式 */overflow: hidden; /* 隐藏溢出内容 */text-overflow: ellipsis; /* 当文本溢出时显示省略号 *//* 对于非WebKit内核浏览器,可以使用以下CSS Grid方案作为备用(但不会显示省略号) */display: grid;grid-template-columns: repeat(auto-fit, minmax(0, 1fr));max-height: .jpgem; /* 调整为所需的行高乘以最大行数 */margin-bottom: .2em; /* 为省略号留出空间(可选) */padding-right: .½em; /* 为省略号留出空间(可选) */
}/* 为非WebKit内核浏览器添加省略号(仅在支持伪元素的浏览器中有效) */
.multi-line-text::after {content: '...'; /* 添加省略号 */position: absolute;right: 0; /* 将省略号定位到右侧 */bottom: 0; /* 将省略号定位到底部 */background-color: white; /* 与背景色相同,覆盖可能的多余文本 */width: .5em; /* 省略号宽度 */height: .5em; /* 省略号高度 */line-height: .5em; /* 保持省略号居中 */text-align: center;
}

应用示例:

<div class="multi-line-text">这是一段非常非常非常非常非常非常长的多行文本,超出指定行数的部分会被隐藏并(在支持的浏览器中)显示省略号...
</div>

在这个例子中,文本将被限制为最多显示3行。当文本内容超过这个限制时,超出的部分将会被隐藏。在支持-webkit-line-clamp属性的浏览器(如基于WebKit内核的Chrome和Safari)中,会在文本末尾自动显示省略号。对于不支持该属性的浏览器,可以尝试使用CSS Grid结合伪元素模拟类似效果,尽管这可能无法精确地在最后一行显示省略号,而是简单地在容器底部附加一个省略号。

请注意,多行文本省略号的实现可能需要针对不同浏览器进行兼容性调整,因为并非所有浏览器都原生支持多行text-overflow: ellipsis。上述示例提供了一种常见的跨浏览器解决方案,但实际应用时可能需要根据目标浏览器的支持情况和项目需求进行调整。

二、文本溢出隐藏能滑动展示隐藏部分

很多时候,默认只展示一部分(单行或者多行),可以通过横向或者纵向滑动展示剩余部分而不是直接省略,体验会更好。

.scroll-text {width: 288rpx;max-height: 148rpx;overflow: scroll; /* 溢出内容可以滚动 */line-height: 44rpx;
}

应用示例:

<div class="scroll-text">这是一段非常非常非常非常非常非常长的文本,超出部分会被隐藏,纵向滑动可以查看隐藏内容
</div>

在这个例子中,当文本长度超过其容器的最高max-height时,超出的部分将会被隐藏,可以通过滑动显示被隐藏部分内容。

三、文本溢出隐藏应用场景

1. 导航菜单项或标签页标题

在有限的空间内,导航菜单项或标签页标题可能包含较长的文本。为了保持导航栏的紧凑性和美观性,可以设置溢出隐藏:

.nav-item,
.tab-title {overflow: hidden;white-space: nowrap;text-overflow: ellipsis;max-width: 100%; /* 或指定一个固定宽度 */
}

2. 卡片或列表项描述

在卡片式布局或列表视图中,每个项目的描述文本可能因内容长度差异导致整体布局不整齐。通过溢出隐藏,可以确保描述始终保持在设定的区域内:

.card-description,
.list-item-content {overflow: hidden;text-overflow: ellipsis;display: -webkit-box;-webkit-line-clamp: 2; /* 可根据需要调整行数 */-webkit-box-orient: vertical;line-height: 1.5; /* 保持适当的行间距 */
}/* 对于不支持 `-webkit-line-clamp` 的浏览器,可以使用以下备用方案 */
.card-description.fallback,
.list-item-content.fallback {max-height: 3.6em; /* 调整为期望的最大行数乘以行高 */margin-bottom: .2em; /* 为省略号留出空间 */padding-right: .5em; /* 为省略号留出空间 */position: relative;
}.card-description.fallback::after,
.list-item-content.fallback::after {content: '...';position: absolute;right: 0;bottom: 0;background-color: white; /* 与背景色相同,覆盖可能的多余文本 */width: .5em;height: .5em;line-height: .5em;text-align: center;
}

3. 表格单元格

表格中,特别是数据密集型表格,单元格内的文本可能过长,影响表格的可读性和美观性。对特定列应用溢出隐藏可以避免这种情况:

table.data-table td.long-text {overflow: hidden;text-overflow: ellipsis;white-space: nowrap;
}/* 如果需要支持多行省略,可以使用以下CSS Grid方案 */
table.data-table td.long-text.multiline {display: grid;grid-template-columns: repeat(auto-fit, minmax(0, 1fr));max-height: 3em; /* 调整为所需的行高乘以最大行数 */
}

4. 用户评论或消息摘要

在论坛、社交媒体或聊天应用中,用户评论或消息摘要常常需要在有限的空间内展示。使用溢出隐藏可以保持界面一致性:

.comment-summary,
.message-preview {overflow: hidden;text-overflow: ellipsis;display: -webkit-box;-webkit-line-clamp: ¾; /* 可根据需要调整行数 */-webkit-box-orient: vertical;
}/* 对于不支持 `-webkit-line-clamp` 的浏览器,可以使用以下备用方案 */
.comment-summary.fallback,
.message-preview.fallback {max-height: 2.¼em; /* 调整为期望的最大行数乘以行高 */margin-bottom: .2em; /* 为省略号留出空间 */padding-right: .5em; /* 为省略号留出空间 */position: relative;
}.comment-summary.fallback::after,
.message-preview.fallback::after {content: '...';position: absolute;right: 0;bottom: 0;background-color: white; /* 与背景色相同,覆盖可能的多余文本 */width: .5em;height: .5em;line-height: .5em;text-align: center;
}

5. 响应式布局中的小屏幕设备

在移动端或小屏幕设备上,为了适应窄小的视口,往往需要对内容进行缩放或截断。文本溢出隐藏在此类场景中尤为重要:

@media (max-width: 767px) {.responsive-text {overflow: hidden;text-overflow: ellipsis;white-space: nowrap;/* 或者针对多行文本使用 -webkit-line-clamp 或 CSS Grid 方案 */}
}

以上列举的场景只是文本溢出隐藏应用的一部分实例,实际上,只要涉及到需要控制文本展示范围以保持布局稳定或视觉美感的地方,都可能用到这一技术。开发者应根据具体的设计需求和浏览器兼容性选择合适的实现方法。

在这里插入图片描述

这篇关于文本溢出体验进阶:CSS 技巧实现单行/多行隐藏展示以及实际场景应用,确保内容可读性和布局整洁性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/921014

相关文章

关于C++中的虚拟继承的一些总结(虚拟继承,覆盖,派生,隐藏)

1.为什么要引入虚拟继承 虚拟继承是多重继承中特有的概念。虚拟基类是为解决多重继承而出现的。如:类D继承自类B1、B2,而类B1、B2都继承自类A,因此在类D中两次出现类A中的变量和函数。为了节省内存空间,可以将B1、B2对A的继承定义为虚拟继承,而A就成了虚拟基类。实现的代码如下: class A class B1:public virtual A; class B2:pu

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

【EverEdit】活用 EverEdit 小技巧

【EverEdit】活用 EverEdit 小技巧 (1)设置 EverEdit 对比文件文本内容 设置如下图所示: 首先要先打开要对比的文本文件,和对比文件相比,此时打开了至少两个文件: 选择文件比较: (2)如何设置 EverEdit 监视文件的变化 设置如下图所示:

乐鑫 Matter 技术体验日|快速落地 Matter 产品,引领智能家居生态新发展

随着 Matter 协议的推广和普及,智能家居行业正迎来新的发展机遇,众多厂商纷纷投身于 Matter 产品的研发与验证。然而,开发者普遍面临技术门槛高、认证流程繁琐、生产管理复杂等诸多挑战。  乐鑫信息科技 (688018.SH) 凭借深厚的研发实力与行业洞察力,推出了全面的 Matter 解决方案,包含基于乐鑫 SoC 的 Matter 硬件平台、基于开源 ESP-Matter SDK 的一

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode

【Linux进阶】UNIX体系结构分解——操作系统,内核,shell

1.什么是操作系统? 从严格意义上说,可将操作系统定义为一种软件,它控制计算机硬件资源,提供程序运行环境。我们通常将这种软件称为内核(kerel),因为它相对较小,而且位于环境的核心。  从广义上说,操作系统包括了内核和一些其他软件,这些软件使得计算机能够发挥作用,并使计算机具有自己的特生。这里所说的其他软件包括系统实用程序(system utility)、应用程序、shell以及公用函数库等

vue, 左右布局宽,可拖动改变

1:建立一个draggableMixin.js  混入的方式使用 2:代码如下draggableMixin.js  export default {data() {return {leftWidth: 330,isDragging: false,startX: 0,startWidth: 0,};},methods: {startDragging(e) {this.isDragging = tr

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为

亮相WOT全球技术创新大会,揭秘火山引擎边缘容器技术在泛CDN场景的应用与实践

2024年6月21日-22日,51CTO“WOT全球技术创新大会2024”在北京举办。火山引擎边缘计算架构师李志明受邀参与,以“边缘容器技术在泛CDN场景的应用和实践”为主题,与多位行业资深专家,共同探讨泛CDN行业技术架构以及云原生与边缘计算的发展和展望。 火山引擎边缘计算架构师李志明表示:为更好地解决传统泛CDN类业务运行中的问题,火山引擎边缘容器团队参考行业做法,结合实践经验,打造火山