我正在创建一个将XML文件解析为XMLDocument对象的工具。我正在使用XML解析器的浏览器实现,例如:

new DOMParser().parseFromString(text,"text/xml");


由于某种原因,我应该在另一个变量中拥有当前XMLDocument对象的副本。

问题是-如何对已解析的xml对象进行深度克隆?

谢谢!

最佳答案

您使用cloneNode(true),而Document继承自Node

var d2 = d.cloneNode(true);


例:



var d = new DOMParser().parseFromString(
  "<root><x><y></y></x></root>",
  "text/xml"
);
// Prove it's a deep clone by removing `y` from `x`:
console.log("d before", d.documentElement.firstChild.children.length);
var x = d.documentElement.firstChild;
var d2 = d.cloneNode(true);
x.removeChild(x.firstChild);
console.log("d after", d.documentElement.firstChild.children.length);
console.log("d2 after", d2.documentElement.firstChild.children.length);

07-27 15:56