本文介绍如何利用正则表达式配合 jQuery 的 attr() 和 replace() 方法,安全、高效地移除 HTML 元素 title 属性中所有嵌入的 HTML 标签(如 <span>、<i> 及其内容),仅保留纯文本。
本文介绍如何利用正则表达式配合 jquery 的 `attr()` 和 `replace()` 方法,安全、高效地移除 html 元素 `title` 属性中所有嵌入的 html 标签(如 ``、`` 及其内容),仅保留纯文本。
在 Web 开发中,有时 title 属性会被动态注入含 HTML 标签的字符串(例如用于图标或星号标记),但浏览器实际渲染 title 时不会解析 HTML,而是将其作为纯文本显示——这会导致用户看到冗余的标签源码(如 Lorem Ipsum... <span class='required'>*</span><i>...</i>),严重影响可读性与用户体验。
正确的处理方式不是逐个匹配特定标签(如 /<span>(.*?)</span>/g),因为该正则存在两个关键缺陷:
✅ 推荐方案:使用贪婪但安全的正则 /<[^>]*>/g —— 它精确匹配任意以 < 开头、> 结尾、中间不含 > 的最短合法标签结构(包括自闭合标签),并支持全局替换:
const $p = $('p');const rawTitle = $p.attr('title');const cleanTitle = rawTitle.replace(/<[^>]*>/g, '').trim();console.log(cleanTitle); // 输出:"Lorem Ipsum is simply dummy "
⚠️ 注意事项:
立即学习“前端免费学习笔记(深入)”;
const rawTitle = $p.attr('title') || '';
? 进阶建议:若需同时清理 HTML 实体(如 )、多余空白或换行,可链式处理:
const cleanTitle = rawTitle .replace(/<[^>]*>/g, '') // 移除所有标签 .replace(/ /g, ' ') // 替换不间断空格 .replace(/s+/g, ' ') // 合并连续空白为单空格 .trim();
总结:清理 title 属性中的 HTML,核心在于理解其文本本质,选用语义明确、边界清晰的正则 /<[^>]*>/g,而非模糊的 /<.*>/。配合 jQuery 的简洁 DOM 操作,即可实现健壮、可维护的标题净化逻辑。