JavaScript文本溢出

在 JavaScript 中,处理文本溢出(Text Overflow)通常涉及检测文本内容是否超出容器的宽度或高度,并根据需要进行截断、省略或动态调整。

1. ​CSS 实现文本溢出省略

如果只需要简单的文本溢出处理,可以使用 CSS 的 text-overflow 属性,结合 white-spaceoverflow 属性来实现。

单行文本溢出省略

css 复制代码
.ellipsis {
  white-space: nowrap;      /* 禁止换行 */
  overflow: hidden;         /* 隐藏溢出内容 */
  text-overflow: ellipsis;  /* 显示省略号 */
  width: 200px;             /* 容器宽度 */
}

多行文本溢出省略

css 复制代码
.multiline-ellipsis {
  display: -webkit-box;
  -webkit-line-clamp: 3;    /* 显示的行数 */
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 200px;
}

2. ​JavaScript 动态截断文本

如果需要在运行时动态截断文本并添加省略号,可以使用 JavaScript。

截断单行文本

ini 复制代码
javascript
function truncateText(element, maxWidth) {
  let text = element.textContent;
  while (element.scrollWidth > maxWidth && text.length > 0) {
    text = text.slice(0, -1); // 每次减少一个字符
    element.textContent = text + '...';
  }
}

const element = document.querySelector('.text');
truncateText(element, 200); // 200px 为容器宽度

截断多行文本

ini 复制代码
javascript
function truncateMultilineText(element, maxLines) {
  const lineHeight = parseInt(window.getComputedStyle(element).lineHeight);
  const maxHeight = lineHeight * maxLines;

  let text = element.textContent;
  while (element.scrollHeight > maxHeight && text.length > 0) {
    text = text.slice(0, -1); // 每次减少一个字符
    element.textContent = text + '...';
  }
}

const element = document.querySelector('.text');
truncateMultilineText(element, 3); // 最多显示 3 行

3. ​结合 CSS 和 JavaScript

可以将 CSS 和 JavaScript 结合使用,实现更灵活的效果。

示例:动态添加省略号

ini 复制代码
html
<div class="text" style="width: 200px; white-space: nowrap; overflow: hidden;">
  这是一个很长的文本内容
</div>
<script>
  const element = document.querySelector('.text');
  if (element.scrollWidth > element.clientWidth) {
    element.title = element.textContent; // 显示完整文本的提示
    element.textContent = element.textContent.slice(0, 10) + '...'; // 截断文本
  }
</script>
相关推荐
2501_920931703 小时前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
0思必得04 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5165 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino5 小时前
图片、文件的预览
前端·javascript
2501_920931706 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05287 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔7 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李7 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN7 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒7 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局