JS如何将用户输入的富文本转换为HTML

来源:IPIPP.com作者:头衔:全栈工程师
导读:本期聚焦于小伙伴创作的《JS如何将用户输入的富文本转换为HTML》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《JS如何将用户输入的富文本转换为HTML》有用,将其分享出去将是对创作者最好的鼓励。

在前端开发中,用户输入富文本后需要将其转换为可渲染的HTML是常见需求,比如评论区、文章编辑器等场景都会用到。下面介绍几种常用的实现方法。

JS如何将用户输入的富文本转换为HTML

原生JS基础转换方式

如果富文本内容本身已经是符合规范的HTML片段,且不需要额外的安全处理,可以直接通过DOM操作实现渲染。核心思路是将富文本内容赋值给容器的innerHTML属性,浏览器会自动解析其中的HTML标签。

// 获取用户输入的富文本内容
const userRichText = '<p>这是用户加粗的<strong>富文本内容</strong></p>';
// 获取用于渲染的容器
const container = document.getElementById('rich-text-container');
// 直接赋值innerHTML完成转换渲染
container.innerHTML = userRichText;

这种方式非常简单,但存在明显的安全风险,如果富文本中包含恶意脚本,会直接执行,因此只适合完全可控的富文本场景。

带安全过滤的转换方式

为了规避XSS攻击风险,在转换前需要对富文本进行安全过滤,移除可能执行脚本的标签和属性。下面的示例实现了基础的过滤逻辑,只保留安全的标签和属性。

function safeRichTextToHtml(richText) {
  // 创建临时容器解析富文本
  const tempDiv = document.createElement('div');
  tempDiv.innerHTML = richText;
  // 定义允许的标签列表
  const allowedTags = ['p', 'div', 'span', 'strong', 'em', 'ul', 'li', 'br'];
  // 遍历所有子节点
  const allElements = tempDiv.querySelectorAll('*');
  allElements.forEach(el => {
    // 如果标签不在允许列表中,替换为文本内容
    if (!allowedTags.includes(el.tagName.toLowerCase())) {
      el.outerHTML = el.textContent;
    }
    // 移除所有on开头的事件属性
    Array.from(el.attributes).forEach(attr => {
      if (attr.name.startsWith('on')) {
        el.removeAttribute(attr.name);
      }
    });
  });
  return tempDiv.innerHTML;
}

// 使用示例
const userInput = '<p onclick="alert(1)">测试<script>alert(2)</script>内容</p>';
const safeHtml = safeRichTextToHtml(userInput);
document.getElementById('safe-container').innerHTML = safeHtml;

使用第三方库实现转换

如果需要更完善的过滤规则,或者处理的富文本格式复杂,推荐使用成熟的第三方库,比如DOMPurify,它可以高效过滤富文本中的恶意内容,同时保留合法的HTML结构。

// 先引入DOMPurify库,这里假设已经通过script标签引入
const userRichText = '<p>用户内容<img src="x" onerror="alert(1)"></p>';
// 使用DOMPurify进行安全过滤
const cleanHtml = DOMPurify.sanitize(userRichText);
// 渲染过滤后的HTML
document.getElementById('purify-container').innerHTML = cleanHtml;

DOMPurify会默认过滤所有危险的标签和属性,同时支持自定义配置,比如允许特定的标签、属性,能够满足大部分场景的需求。

注意事项

  • 转换前一定要确认富文本内容的来源,不可信的内容必须做安全过滤,避免XSS攻击。
  • 如果富文本中包含用户输入的特殊字符,比如<、>等,需要提前做好转义,避免解析异常。
  • 不同浏览器对HTML的解析规则略有差异,测试时建议在多浏览器环境下验证渲染效果。
  • 如果富文本中包含图片、视频等资源,需要额外校验资源地址的合法性,避免加载恶意资源。
转换方式优点缺点适用场景
原生innerHTML直接赋值实现简单,无额外依赖无安全过滤,风险高完全可控的内部富文本内容
自定义过滤转换可定制化过滤规则规则不完善易留漏洞简单场景的轻量过滤需求
第三方库(如DOMPurify)过滤规则完善,安全性高需要引入额外依赖用户提交的不可信富文本内容
提示:生产环境中优先选择成熟的第三方库处理富文本转换,不要自行实现复杂的安全过滤逻辑,避免遗漏安全风险。

以上就是JS将用户输入富文本转换为HTML的几种常用方法,开发者可以根据实际场景选择合适的方案,同时注意保障转换过程的安全性。

富文本转换JavaScriptHTML渲染内容转义用户输入处理修改时间:2026-05-25 11:07:08

免责声明:已尽一切努力确保本网站所含信息的准确性。网站部分内容来源于网络或由用户自行发表,内容观点不代表本站立场。本站是个人网站免费分享,内容仅供个人学习、研究或参考使用,如内容中引用了第三方作品,其版权归原作者所有。若内容触犯了您的权益,请联系我们进行处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。前端、网络、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握网站开发与运维所需的核心技术栈。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端逻辑,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。