让文本超出两行自动展开,并显示“展开”按钮的技巧
本文介绍如何使用CSS和JavaScript实现文本超出两行时自动展开,并添加“展开”按钮的功能。
首先,利用CSS控制文本显示行数,并隐藏超出部分:
.text-container {
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
}
这段代码将文本容器限制在两行显示,超出部分将被隐藏。
接下来,JavaScript代码用于判断文本是否超出两行:
const element = document.querySelector('.text-container');
if (element.scrollHeight > element.clientHeight) {
// 超出两行
} else {
// 未超出两行
}
scrollHeight
表示元素内容的实际高度,clientHeight
表示元素可见区域的高度。如果scrollHeight
大于clientHeight
,则表示内容超出两行。
最后,通过CSS添加“展开”按钮,并使用JavaScript控制按钮的显示和文本的展开/收起:
.expand-button {
position: relative; /* 或 absolute,根据需要调整 */
display: none; /* 默认隐藏 */
cursor: pointer;
}
.text-container.expanded {
-webkit-line-clamp: initial; /* 取消行数限制 */
overflow: visible; /* 显示全部内容 */
}
.text-container.expanded + .expand-button {
display: inline-block; /* 展开后显示按钮 */
}
JavaScript代码则负责在检测到文本超出两行时显示按钮,点击按钮时切换文本容器的expanded
类,从而实现展开/收起效果。 具体的JavaScript实现逻辑可以参考这篇SegmentFault文章。
通过以上步骤,您可以轻松实现文本超出两行自动展开并添加“展开”按钮的功能,提升用户体验。 请根据实际需求调整CSS样式和JavaScript代码。