首页 > 文章列表 > 文本超出两行如何自动展开并显示“展开”按钮?

文本超出两行如何自动展开并显示“展开”按钮?

359 2025-03-16

文本超出两行如何自动展开并显示“展开”按钮?

让文本超出两行自动展开,并显示“展开”按钮的技巧

本文介绍如何使用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代码。

来源:1740085966