答案:JavaScript通过DOMParser和fetch可解析XML。先用fetch获取XML字符串,再用DOMParser转为DOM结构,通过querySelector或getElementsByTagName读取节点,需检查parsererror确保解析成功,且注意XML大小写敏感与标签闭合。
JavaScript 可以通过内置的 DOMParser 和 XMLHttpRequest(或 fetch)来解析和处理 XML 数据。无论是在浏览器环境还是 Node.js 中,处理方式略有不同,下面主要介绍浏览器端的常见做法。
DOMParser 是浏览器提供的原生对象,可以将 XML 字符串转换为可操作的 DOM 结构。
示例代码:
const xmlString = `
ector("parsererror");
if (errorNode) {
console.error("XML 解析出错", errorNode.textContent);
} else {
const books = xmlDoc.querySelectorAll("book");
books.forEach(book => {
const id = book.getAttribute("id");
const title = book.querySelector("title").textContent;
const author = book.querySelector("author").textContent;
console.log(`ID: ${id}, 书名: ${title}, 作者: ${author}`);
});
}
可以使用 fetch API 获取远程 XML 文件,再用 DOMParser 解析。
示例代码:
fetch('books.xml') .then(response => response.text()) .then(str => { const parser = new DOMParser(); const xmlDoc = parser.parseFromString(str, "text/xml"); // 检查解析错误 if (xmlDoc.querySelector("parsererror")) { console.error("XML 文件格式错误"); return; } const titles = xmlDoc.getElementsByTagName("title"); for (let i = 0; i console.error("请求失败:", err));解析后的 XML 文档可以像 HTML DOM 一样操作:
处理 XML 时需要注意以下几点:
基本上就这些。浏览器中原生支持 XML 解析,关键在于正确使用 DOMParser 并检查解析是否成功。不复杂但容易忽略错误处理。