全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JS的DOMParser和XMLSerializer怎么用

DOMParser 和 XMLSerializer 是浏览器原生 API,分别用于字符串与 DOM 对象互转:前者用 parseFromString() 解析 HTML/XML 字符串为 Document,后者用 serializeToString() 将节点序列化为字符串;配合使用可安全修改 HTML 再转回字符串。

DOMParser 和 XMLSerializer 是浏览器中处理 HTML/XML 字符串与 DOM 对象互转的两个核心 API。前者把字符串解析成文档对象,后者把文档对象序列化回字符串。它们不依赖外部库,轻量且原生支持好。

用 DOMParser 解析 HTML 或 XML 字符串

DOMParser 可以将一段字符串安全地转为可操作的 Document 对象,常用于动态生成 DOM、解析远程 HTML 片段或校验 XML 结构。

  • 创建实例后调用 parseFromString(),传入字符串和 MIME 类型("text/html""application/xml"
  • 对 HTML 字符串,推荐用 "text/html",这样会走标准 HTML 解析器,自动修复常见错误(如缺失闭合标签)
  • 对 XML 字符串,必须用 "application/xml"(或 "text/xml"),否则可能解析失败或忽略命名空间

示例:

const parser = new DOMParser();
const htmlDoc = parser.parseFromString("

Hello

", "text/html"); console.log(htmlDoc.body.firstElementChild.textContent); // "Hello" const xmlStr = ""; const xmlDoc = parser.parseFromString(xmlStr, "application/xml"); if (xmlDoc.querySelector("parsererror")) { console.error("XML 解析出错"); }

用 XMLSerializer 序列化 DOM 回字符串

XMLSerializer 主要用于把 Document、Element 等节点对象还原成字符串,适合做 DOM 快照、生成 HTML 模板、提取子树内容等。

  • 只接受 Node 实例(如 document、element、documentFragment),不能传字符串或普通对象
  • 对 HTML 文档,输出的是“序列化后的 HTML”,不是原始源码(比如会补全 结构)
  • 若只想序列化某个元素及其子内容,直接传该 element 即可,无需整个 document

示例:

const serializer = new XMLSerializer();
const div = htmlDoc.querySelector("div");
console.log(serializer.serializeToString(div)); // "

Hello

"

配合使用:修改后再转回字符串

这是常见工作流:字符串 → DOM → 修改节点 → 转回字符串。比正则替换更可靠,尤其涉及嵌套、属性、特殊字符时。

  • 先用 DOMParser 解析,再用 querySelector / appendChild / setAttribute 等方法操作
  • 操作完成后,用 XMLSerializer 把目标元素(或 document.documentElement)序列化
  • 注意:HTML 中 script/style 标签的内容不会被自动执行,只是文本节点,安全

示例(给所有链接加 target="_blank"):

const html = "LinkExt";
const doc = new DOMParser().parseFromString(html, "text/html");
doc.querySelectorAll("a").forEach(a => a.target = "_blank");
const result = new XMLSerializer().serializeToString(doc.body);
// "LinkExt"

注意事项和兼容性

这两个 API 在现代浏览器中支持良好(Chrome 1+、Firefox 2+、Safari 3.1+、Edge 12+),但仍有细节需留意:

  • DOMParser 解析失败时不会抛异常,而是返回含 的文档,需手动检查
  • XMLSerializer 对 HTML 文档序列化时,会标准化大小写(如 )、添加缺失结构,不保留原始格式缩进
  • 不支持序列化 Shadow DOM 内容(仅限 light DOM)
  • 服务端 Node.js 不原生支持,需用 jsdom 等库模拟


# html  # js  # node.js  # node  # 浏览器  # app  # edge  # safari  # 字符串解析  # firefox  # chrome  # 命名空间  # xml  # 字符串 


相关文章: 网站制作壁纸教程视频,电脑壁纸网站?  高端企业智能建站程序:SEO优化与响应式模板定制开发  如何配置FTP站点权限与安全设置?  建站主机服务器选购指南:轻量应用与VPS配置解析  广德云建站网站建设方案与建站流程优化指南  建站之星各版本价格是多少?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  如何快速生成高效建站系统源代码?  建站VPS推荐:2025年高性能服务器配置指南  建站之星导航菜单设置与功能模块配置全攻略  如何零成本快速生成个人自助网站?  如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本  建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南  ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?  如何通过万网虚拟主机快速搭建网站?  SQL查询语句优化的实用方法总结  网站制作报价单模板图片,小松挖机官方网站报价?  企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  c# 在ASP.NET Core中管理和取消后台任务  零基础网站服务器架设实战:轻量应用与域名解析配置指南  如何用y主机助手快速搭建网站?  详解jQuery停止动画——stop()方法的使用  如何快速启动建站代理加盟业务?  建站之星图片链接生成指南:自助建站与智能设计教程  股票网站制作软件,网上股票怎么开户?  表情包在线制作网站免费,表情包怎么弄?  怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  自助网站制作软件,个人如何自助建网站?  如何在阿里云部署织梦网站?  如何快速搭建FTP站点实现文件共享?  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  如何选择域名并搭建高效网站?  建站168自助建站系统:快速模板定制与SEO优化指南  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  如何快速搭建高效简练网站?  如何在Windows环境下新建FTP站点并设置权限?  c# 在高并发下使用反射发射(Reflection.Emit)的性能  长沙企业网站制作哪家好,长沙水业集团官方网站?  整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  如何在Golang中引入测试模块_Golang测试包导入与使用实践  大同网页,大同瑞慈医院官网?  南宁网站建设制作定制,南宁网站建设可以定制吗?  建站之星后台管理如何实现高效配置?  建站主机助手选型指南:2025年热门推荐与高效部署技巧  潮流网站制作头像软件下载,适合母子的网名有哪些?  开源网站制作软件,开源网站什么意思? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。