The Document
object's importNode()
method creates a copy of a Node
or DocumentFragment
from another document, to be inserted into the current document later.
The imported node is not yet included in the document tree. To include it, you need to call an insertion method such as appendChild()
or insertBefore()
with a node that is currently in the document tree.
Unlike document.adoptNode()
, the original node is not removed from its original document. The imported node is a clone of the original.
var node = document.importNode(externalNode, deep);
Node.parentNode
is null
, since it has not yet been inserted into the document tree.Node
or DocumentFragment
to import into the current document.true
, then externalNode and all of its descendants are copied.false
, then only externalNode is imported — the new node has no children.Note: In the DOM4 specification, deep was an optional argument with a default value of true
.
This default has changed in the latest spec — the new default value is false
. Though it's still an optional argument, you should always provide the deep
argument for backward and forward compatibility. With Gecko 28.0 (Firefox 28 / Thunderbird 28 / SeaMonkey 2.25 / Firefox OS 1.3), the console warns developers not to omit the argument. Starting with Gecko 29.0 (Firefox 29 / Thunderbird 29 / SeaMonkey 2.26)), a shallow clone is defaulted instead of a deep clone.
var iframe = document.querySelector("iframe"); var oldNode = iframe.contentWindow.document.getElementById("myNode"); var newNode = document.importNode(oldNode, true); document.getElementById("container").appendChild(newNode);
Nodes from external documents should be cloned using document.importNode()
(or adopted using document.adoptNode()
) before they can be inserted into the current document. For more on the Node.ownerDocument
issues, see the W3C DOM FAQ.
Firefox doesn't currently enforce this rule (it did for a while during the development of Firefox 3, but too many sites break when this rule is enforced). We encourage Web developers to fix their code to follow this rule for improved future compatibility.
Specification | Status | Comment |
---|---|---|
DOM The definition of 'document.importNode()' in that specification. | Living Standard | |
Document Object Model (DOM) Level 2 Core Specification The definition of 'document.importNode()' in that specification. | Obsolete | Initial definition |
Desktop | ||||||
---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | |
Basic support | Yes | Yes | 4 | 9 | 9 | Yes |
deep parameter optional |
Yes | Yes | 10 | No | Yes | Yes |
Mobile | |||||||
---|---|---|---|---|---|---|---|
Android webview | Chrome for Android | Edge Mobile | Firefox for Android | Opera for Android | iOS Safari | Samsung Internet | |
Basic support | Yes | Yes | 12 | 4 | 9 | Yes | ? |
deep parameter optional |
Yes | Yes | Yes | 10 | Yes | Yes | ? |
© 2005–2018 Mozilla Developer Network and individual contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/document/importNode