将JSDOM解析的XML保存为文件

时间:2020-01-09 17:07:43

标签: javascript node.js xml jsdom

我可以这样解析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的根元素。它还会产生所有小写字母。

1 个答案:

答案 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;