DOMDocument::adoptNode

ノードを別のドキュメントに移す

説明

public DOMNodefalse DOMDocument::adoptNode(DOMNode $node)

ノードを別のドキュメントから、現在のドキュメントに移します。

パラメータ

node

移すノード

戻り値

移したノードを返します。エラー時に false を返します。

エラー / 例外

DOM_NOT_SUPPORTED_ERR

ノードの型が、転送先のノードでサポートされていない場合に発生します。

例1 DOMDocument::adoptNode の例

最初のドキュメントの hello 要素を二番目のものに移します。

<?php
$doc1 = new DOMDocument;
$doc1->loadXML("<container><hello><world/></hello></container>");
$hello = $doc1->documentElement->firstChild;

$doc2 = new DOMDocument;
$doc2->loadXML("<root/>");
$doc2->documentElement->appendChild($doc2->adoptNode($hello));

echo $doc1->saveXML() . PHP_EOL;
echo $doc2->saveXML();
?>

上の例の出力は以下となります。

<?xml version="1.0"?>
<container/>

<?xml version="1.0"?>
<root><hello><world/></hello></root>

参考

  • DOMDocument::importNode