0

0

js 如何解析XML数据

月夜之吻

月夜之吻

发布时间:2025-08-13 10:56:01

|

445人浏览过

|

来源于php中文网

原创

在javascript中解析xml数据主要有两种方法:1. 使用domparser解析xml字符串,通过new domparser()创建解析器并调用parsefromstring方法将xml字符串转换为dom文档,随后使用dom api如getelementsbytagname或getelementsbytagnamens(处理命名空间)提取数据;2. 使用xmlhttprequest获取远程xml文件,在onload事件中通过xhr.responsexml获取解析后的dom文档,并检查其有效性以确保解析成功;对于格式错误的xml,可通过检测parsererror元素判断解析是否失败;domparser适用于本地小数据量解析,性能较高,而xmlhttprequest适合从服务器异步加载xml数据,避免阻塞主线程,处理大型文件时可结合流式解析器优化内存使用。

js 如何解析XML数据

在 JavaScript 中解析 XML 数据,主要涉及将 XML 字符串转换为可操作的 JavaScript 对象,这样你就可以方便地提取和使用 XML 数据中的信息。通常,你会使用

DOMParser
XMLHttpRequest
对象来实现这一点。

解决方案:

JavaScript 解析 XML 的方法主要有两种:使用

DOMParser
直接解析 XML 字符串,或者使用
XMLHttpRequest
获取 XML 数据并解析。

如何使用
DOMParser
解析 XML 字符串?

DOMParser
是一个内置的 JavaScript 对象,它可以将 XML 或 HTML 字符串解析为 DOM 文档。以下是一个简单的例子:

const xmlString = `<bookstore>
  <book category="cooking">
    <title lang="en">Everyday Italian</title>
    <author>Giada De Laurentiis</author>
    <year>2005</year>
    <price>30.00</price>
  </book>
  <book category="children">
    <title lang="en">Harry Potter</title>
    <author>J.K. Rowling</author>
    <year>2005</year>
    <price>29.99</price>
  </book>
</bookstore>`;

const parser = new DOMParser();
const xmlDoc = parser.parseFromString(xmlString, "application/xml");

// 现在你可以使用 DOM API 来访问 XML 数据
const books = xmlDoc.getElementsByTagName("book");
for (let i = 0; i < books.length; i++) {
  const title = books[i].getElementsByTagName("title")[0].textContent;
  const author = books[i].getElementsByTagName("author")[0].textContent;
  console.log(`Title: ${title}, Author: ${author}`);
}

这里,我们首先创建了一个 XML 字符串。然后,我们实例化

DOMParser
对象,并使用
parseFromString
方法将 XML 字符串转换为 DOM 文档。
"application/xml"
参数告诉解析器这是一个 XML 文档。之后,你就可以使用标准的 DOM API(如
getElementsByTagName
)来访问和提取数据了。

如何使用
XMLHttpRequest
获取并解析 XML 数据?

如果你的 XML 数据存储在服务器上,你需要使用

XMLHttpRequest
对象来获取它。这是一个例子:

AssemblyAI
AssemblyAI

转录和理解语音的AI模型

下载
const xhr = new XMLHttpRequest();
xhr.open("GET", "books.xml", true); // 假设你的 XML 文件名为 books.xml

xhr.onload = function() {
  if (xhr.readyState === 4 && xhr.status === 200) {
    const xmlDoc = xhr.responseXML; // 获取 XML 文档对象

    // 检查是否成功解析 XML
    if (xmlDoc) {
      const books = xmlDoc.getElementsByTagName("book");
      for (let i = 0; i < books.length; i++) {
        const title = books[i].getElementsByTagName("title")[0].textContent;
        const author = books[i].getElementsByTagName("author")[0].textContent;
        console.log(`Title: ${title}, Author: ${author}`);
      }
    } else {
      console.error("Failed to parse XML.");
    }
  } else {
    console.error("Failed to load XML.");
  }
};

xhr.onerror = function() {
  console.error("Network error occurred.");
};

xhr.send();

这个例子中,我们创建了一个

XMLHttpRequest
对象,并使用
open
方法指定了请求类型(GET)和 URL。
onload
事件处理程序在请求完成时被调用。
xhr.responseXML
属性包含了 XML 文档对象。如果
responseXML
null
,则表示解析失败,可能是因为 XML 格式不正确。

处理 XML 中的命名空间

XML 命名空间用于避免元素名称冲突。如果你的 XML 文档使用了命名空间,你需要使用

getElementsByTagNameNS
而不是
getElementsByTagName
来选择元素。例如:

const xmlStringWithNS = `<root xmlns:bk="http://example.com/books">
  <bk:book>
    <bk:title>My Book</bk:title>
  </bk:book>
</root>`;

const parser = new DOMParser();
const xmlDoc = parser.parseFromString(xmlStringWithNS, "application/xml");

const books = xmlDoc.getElementsByTagNameNS("http://example.com/books", "book");
if (books.length > 0) {
  const title = books[0].getElementsByTagNameNS("http://example.com/books", "title")[0].textContent;
  console.log(`Title: ${title}`);
}

在这个例子中,我们使用了

getElementsByTagNameNS
方法,它接受两个参数:命名空间 URI 和本地名称。

如何处理 XML 解析错误?

XML 解析可能会因为 XML 格式不正确而失败。

DOMParser
提供了一个
parseError
属性,你可以使用它来检查解析是否成功。

const xmlString = `<bookstore>
  <book>
    <title>Invalid XML - Missing closing tag</title>
  </book>`; // 缺少 </bookstore> 闭合标签

const parser = new DOMParser();
const xmlDoc = parser.parseFromString(xmlString, "application/xml");

const errorNode = xmlDoc.querySelector("parsererror");
if (errorNode) {
  console.error("XML Parsing Error:", errorNode.textContent);
} else {
  const books = xmlDoc.getElementsByTagName("book");
  // ... 正常处理 XML
}

这个例子中,我们检查了

parsererror
元素是否存在。如果存在,则表示解析过程中发生了错误。注意,不同的浏览器可能使用不同的方式来表示解析错误,因此最好检查
parsererror
元素是否存在,而不是依赖于特定的错误消息。

性能考虑:哪种解析方法更快?

通常来说,

DOMParser
在处理较小的 XML 字符串时更快,因为它避免了网络请求的开销。但是,如果你的 XML 数据存储在服务器上,或者你需要处理非常大的 XML 文件,那么使用
XMLHttpRequest
异步加载数据可能更合适,因为它不会阻塞主线程。另外,对于大型 XML 文件,可以考虑使用流式解析器,例如
xml-stream
库,以减少内存占用

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1109

2024.03.01

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1949

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2119

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1171

2024.11.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1570

2023.10.24

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
XQuery 教程
XQuery 教程

共12课时 | 4.5万人学习

XSL-FO 教程
XSL-FO 教程

共14课时 | 9.4万人学习

如何进行WebSocket调试
如何进行WebSocket调试

共1课时 | 0.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号