如何用纯 JavaScript 实现标题字符长度限制(60 字符截断)

1次阅读

如何用纯 JavaScript 实现标题字符长度限制(60 字符截断)

本文详解如何使用原生 javascript 为 html 元素实现标题文本长度限制(如最多显示 60 字符,超长自动截断并添加省略号),纠正 jquery 风格代码在原生环境中的常见错误,并提供健壮、可复用的解决方案。

本文详解如何使用原生 javascript 为 html 元素实现标题文本长度限制(如最多显示 60 字符,超长自动截断并添加省略号),纠正 jquery 风格代码在原生环境中的常见错误,并提供健壮、可复用的解决方案。

在前端开发中,对动态渲染的标题(如新闻标题、卡片标题)进行长度控制是常见需求。当使用纯 javascript(即“vanilla js”)替代 jQuery 时,开发者常因语法差异导致功能失效——例如误用 .each()、.text() 等 jQuery 方法,而这些在原生 dom API 中并不存在。

以下是正确、现代且可扩展的实现方案:

✅ 核心修正要点

  • ❌ document.querySelector(“.limiter”).each(…) → 不合法:querySelector 返回单个元素,且无 .each() 方法;
  • ✅ 应改用 document.querySelectorAll(‘.limiter’) 获取所有匹配元素(返回 NodeList),再通过 foreach 遍历;
  • ❌ .text() → 不存在:原生 JS 使用 textContent(保留空白与标签结构)或 innerText(按渲染效果读取,受 CSS 影响);此处推荐 textContent 保证语义准确;
  • var a = 60; var b = … → 建议使用 const/let 提升可维护性与作用域安全性;
  • ❌ b.substring(0, a + 1) + ” …” → 易引发边界问题(如 a=60 时取 61 字符再加 … 导致总长 64);应明确「最多显示 limit 个字符 + …」,即截取前 limit – 3 位。

✅ 推荐实现代码(含容错处理)

// 定义最大显示长度(含省略号占位) const TITLE_LIMIT = 60;  // 获取所有需限制的元素 document.querySelectorAll('.limiter').forEach(el => {   // 获取并清理原始文本(去除首尾空格,避免误判换行/缩进)   const rawText = el.textContent;   const trimmedText = rawText ? rawText.trim() : '';    // 若文本为空或未超限,无需处理   if (!trimmedText || trimmedText.length <= TITLE_LIMIT) {     return;   }    // 安全截断:预留 3 字符给 '...',防止总长溢出   const cutoff = Math.max(0, TITLE_LIMIT - 3);   const truncated = trimmedText.slice(0, cutoff) + '...';    // 更新 DOM   el.textContent = truncated; });

✅ HTML 示例(支持多元素批量处理)

<div class="limiter">   Pandemic deaths are spiraling out of control since the opening of the country and now we test the limiter </div> <div class="limiter">   Lions and Tigers and Bears, Oh My! </div> <div class="limiter">   <!-- 空内容或仅空白 -->  </div>

⚠️ 注意事项与最佳实践

  • 性能考量:若元素数量极大(如数百个),建议在 DOMContentLoaded 后执行,或结合 IntersectionObserver 懒处理可视区域内的标题;
  • 国际化适配:中文、日文等字符均为单字节长度,本方案天然兼容;但若需按「视觉宽度」或「字数」(非字节数)截断,需引入 Intl.Segmenter 或第三方库;
  • 可访问性(a11y):截断后丢失的信息可能影响屏幕阅读器体验。如需增强可访问性,可添加 title 属性保留完整文本:
    el.title = rawText; // 鼠标悬停显示全文
  • CSS 辅助方案:对于纯展示型标题,也可考虑 text-overflow: ellipsis(需配合 white-space: nowrap 和固定宽高),但该方案不适用于多行文本,且无法精确控制字符数。

✅ 总结

纯 JavaScript 实现标题长度限制的关键在于:正确选取元素(querySelectorAll)、合理遍历(forEach)、精准读写文本(textContent)、安全截断(预留省略号长度)。摒弃 jQuery 惯性思维,拥抱现代 es6+ 语法(const、箭头函数、模板字符串),不仅能提升代码健壮性,也为后续维护与协作奠定基础。

text=ZqhQzanResources