--- title: DocumentFragment slug: Web/API/DocumentFragment tags: - API - DOM - Document - Fragments - Interface - Noeuds translation_of: Web/API/DocumentFragment ---
{{ ApiRef("DOM") }}
L’interface DocumentFragment
représente un objet document minimal qui n’a pas de parent. Il est utilisé comme une version légère de {{domxref("Document")}} pour stocker un segment de structure de document composé de nœuds, tout comme un document standard. La différence fondamentale est que, comme le fragment de document ne fait pas réellement partie de la structure du DOM, les changements faits au fragment n’affectent pas le document, ne causent pas de {{Glossary("Reflow")}} , et ne provoquent pas les éventuels impacts de performance qui peuvent avoir lieu quand des changements sont faits.
Un usage courant de DocumentFragment
est de créer un fragment, assembler un sous-arbre DOM au sein de celui-ci, puis ajouter ou insérer le fragment dans le DOM en utilisant les méthodes de l’interface {{domxref("Node")}} (telles que {{domxref("Node.appendChild", "appendChild()")}} ou {{domxref("Node.insertBefore", "insertBefore()")}}). En faisant ainsi, on place les nœuds du fragment dans le DOM, en laissant derrière un DocumentFragment
vide. Comme tous les nœuds sont insérés dans le document en une seule fois, un seul reflow et un seul rendu sont déclenchés, au lieu de potentiellement un pour chaque nœud inséré s’ils avaient été insérés séparément.
Cette interface est également beaucoup utilisée avec les Web components : les éléments {{HTMLElement("template")}} contiennent un DocumentFragment
dans leur propriété {{domxref("HTMLTemplateElement.content")}}.
Un DocumentFragment
vide peut être créé en utilisant la méthode {{domxref("document.createDocumentFragment()")}} ou le constructeur.
{{InheritanceDiagram}}
Cette interface n’a pas de propriétés spécifiques, mais hérite de celles de son parent, {{domxref("Node")}}, et implémente celles de l’interface {{domxref("ParentNode")}}.
DocumentFragment
.DocumentFragment
, ou null
s’il n’y en a aucun.DocumentFragment
, ou null
s’il n’y en a aucun.unsigned long
indiquant le nomble d’enfants que le DocumentFragment
possède.DocumentFragment
vide.Cette interface hérite des méthodes de son parent, {{domxref("Node")}}, et implémente celles de l’interface {{domxref("ParentNode")}}.
DocumentFragment
, dans l’ordre du document, correspondant aux sélécteurs spécifiés.DocumentFragment
qui correspondent aux sélecteurs spécifiés.DocumentFragment
, dans l’ordre du document, qui correspond à l’ID spécifié.Spécification | Statut | Commentaire |
---|---|---|
{{SpecName('DOM WHATWG', '#interface-documentfragment', 'DocumentFragment')}} | {{Spec2('DOM WHATWG')}} | Ajouté le constructeur et l’implémentation de {{domxref("ParentNode")}}. |
{{SpecName('Selectors API Level 1', '#the-apis', 'DocumentFragment')}} | {{Spec2('Selectors API Level 1')}} | Ajouté les méthodes querySelector() et querySelectorAll() . |
{{SpecName('DOM3 Core', 'core.html#ID-B63ED1A3', 'DocumentFragment')}} | {{Spec2('DOM3 Core')}} | Pas de changement depuis {{SpecName('DOM2 Core')}} |
{{SpecName('DOM2 Core', 'core.html#ID-B63ED1A3', 'DocumentFragment')}} | {{Spec2('DOM2 Core')}} | Pas de changement depuis {{SpecName('DOM1')}} |
{{SpecName('DOM1', 'level-one-core.html#ID-B63ED1A3', 'DocumentFragment')}} | {{Spec2('DOM1')}} | Définition initiale |
{{Compat("api.DocumentFragment")}}