-
Notifications
You must be signed in to change notification settings - Fork 164
Expand file tree
/
Copy pathimportnode.xml
More file actions
150 lines (137 loc) · 4.01 KB
/
importnode.xml
File metadata and controls
150 lines (137 loc) · 4.01 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 4f5e2b22575131fa5e9c3004b1c874e1acb06573 Maintainer: yannick Status: ready -->
<!-- Reviewed: yes -->
<refentry xml:id="domdocument.importnode" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>DOMDocument::importNode</refname>
<refpurpose>Importe un nœud dans le document courant</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis role="DOMDocument">
<modifier>public</modifier> <type class="union"><type>DOMNode</type><type>false</type></type><methodname>DOMDocument::importNode</methodname>
<methodparam><type>DOMNode</type><parameter>node</parameter></methodparam>
<methodparam choice="opt"><type>bool</type><parameter>deep</parameter><initializer>&false;</initializer></methodparam>
</methodsynopsis>
<para>
Cette fonction retourne une copie du nœud à importer et l'associe avec le
document courant.
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>node</parameter></term>
<listitem>
<para>
Le nœud à importer.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>deep</parameter></term>
<listitem>
<para>
Si défini à &true;, cette méthode importera
récursivement le sous-arbre situé sous le nœud
<parameter>node</parameter>.
</para>
<note>
<para>
Pour copier les attributs des nœuds, le paramètre
<parameter>deep</parameter> doit être défini à &true;
</para>
</note>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Le nœud copié ou &false; si la copie a échoué.
</para>
</refsect1>
<refsect1 role="errors">
&reftitle.errors;
<para>
Une <classname>DOMException</classname> est lancée si le nœud ne
peut pas être importé.
</para>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>Exemple avec <function>DOMDocument::importNode</function></title>
<para>
Copie de nœuds entre plusieurs documents.
</para>
<programlisting role="php">
<![CDATA[
<?php
$orgdoc = new DOMDocument;
$orgdoc->loadXML("<root><element><child>Texte dans un fils</child></element></root>");
// Le nœud que nous voulons importer dans le nouveau document
$node = $orgdoc->getElementsByTagName("element")->item(0);
// Création du nouveau document
$newdoc = new DOMDocument;
$newdoc->formatOutput = true;
// Ajout de quelques balises
$newdoc->loadXML("<root><someelement>Texte dans un élément</someelement></root>");
echo "Le nouveau document avant d'y copier le nœud :\n";
echo $newdoc->saveXML();
// Importation du nœud, ainsi que tous ses fils, dans le document
$node = $newdoc->importNode($node, true);
// Et on l'ajoute dans le nœud racine "<root>"
$newdoc->documentElement->appendChild($node);
echo "\nLe nouveau document après y avoir copié les nœuds :\n";
echo $newdoc->saveXML();
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
Le nouveau document avant d'y copier le nœud :
<?xml version="1.0"?>
<root>
<someelement>Texte dans un élément</someelement>
</root>
Le nouveau document après y avoir copié les nœuds :
<?xml version="1.0"?>
<root>
<someelement>Texte dans un élément</someelement>
<element>
<child>Texte dans un fils</child>
</element>
</root>
]]>
</screen>
</example>
</para>
</refsect1>
</refentry>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->