我正在创建一个将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);