我可以这样解析XML:
import JSDOM from "jsdom";
const myXml = "... some xml loaded from somewhere ...";
const dom = new JSDOM.JSDOM(myXml);
当我用Google搜索“ jsdom save xml” 时,我真的很惊讶,却一无所获。我认为JSDOm是最流行的XML操作库之一。
在一个答案中,我已经看到了:
window.document.documentElement.outerHTML
由于某种原因而产生垃圾代码,例如,它将转换为
<Node>
<Child attr="attr"/>
<Child attr="attr"/>
<Child attr="attr"/>
<Child attr="attr"/>
</Node>
到
<Node>
<Child attr="attr">
<Child attr="attr">
<Child attr="attr">
<Child attr="attr">
</Child></Child></Child></Child>
</Node>
它也以以下内容开头文档:
<html><head></head><body><globe xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
请注意,Globe
是源XML的根元素。它还会产生所有小写字母。
答案 0 :(得分:3)
保存文档的方法是正确的。但是解析方法是错误的。 JSDOM
需要HTML并创建浏览器DOM的实例。而且必须这样使用,因此步骤与在浏览器中解析XML时相同:
// Create empty DOM, the imput param here is for HTML not XML, and we don want to parse HTML
const dom = new JSDOM.JSDOM("");
// Get DOMParser, same API as in browser
const DOMParser = dom.window.DOMParser;
const parser = new DOMParser;
// Create document by parsing XML
const document = parser.parseFromString(xml, "text/xml");
// save the xml after modifications
const xmlString = document.documentElement.outerHTML;