--- title: Document.adoptNode() slug: Web/API/Document/adoptNode tags: - API - DOM - DOM Reference - Method - NeedsExample - NeedsSpecTable - NeedsUpdate - Reference translation_of: Web/API/Document/adoptNode ---
Document.adoptNode()
は、{{Glossary("node/dom", "ノード")}}を他の{{domxref("Document", "文書", "", "1")}}からメソッドの文書へ移動します。取り込まれたノードおよびそのサブツリーは (もしあれば) 元の文書から削除され、 {{domxref("Node.ownerDocument", "ownerDocument")}} が現在の文書に変更されます。その後、ノードを現在の文書に挿入することができます。
const importedNode = document.adoptNode(externalNode);
externalNode
インポートする文書のスコープ内にコピーされた importedNode
。
このメソッドを呼び出した後、 importedNode
および externalNode
は同じオブジェクトになります。
注: importedNode
の {{domxref("Node.parentNode")}} は、まだ文書ツリーに挿入されていないので null
です。
const iframe = document.querySelector('iframe'); const iframeImages = iframe.contentDocument.querySelectorAll('img'); const newParent = document.getElementById('images'); iframeImages.forEach(function(imgEl) { newParent.appendChild(document.adoptNode(imgEl)); });
外部の文書から取り込まれるノードは、現在の文書に挿入する前に、次のいずれかを実行してください。
ベストプラクティス: Firefox は現在はこの規則を強制しませんが、将来の互換性を向上するためにこの規則に従うことを強くお勧めします。
{{domXref("Node.ownerDocument")}} の問題についての詳細は、 W3C DOM FAQ を参照してください。
仕様書 | 状態 | 備考 |
---|---|---|
{{SpecName('DOM WHATWG', '#dom-document-adoptnode', 'document.adoptNode')}} | {{Spec2('DOM WHATWG')}} |
{{Compat("api.Document.adoptNode")}}