Creates a new empty DocumentFragment
into which DOM nodes can be added to build an offscreen DOM tree.
On this page
Document: createDocumentFragment() method
Syntax
js
createDocumentFragment()
Parameters
None.
Return value
A newly created, empty, DocumentFragment
object, which is ready to have nodes inserted into it.
Usage notes
DocumentFragment
s are DOM Node
objects which are never part of the main DOM tree. The usual use case is to create the document fragment, append elements to the document fragment and then append the document fragment to the DOM tree. In the DOM tree, the document fragment is replaced by all its children.
Since the document fragment is in memory and not part of the main DOM tree, appending children to it does not cause page reflow (computation of element's position and geometry). Historically, using document fragments could result in better performance.
You can also use the DocumentFragment
constructor to create a new fragment:
js
const fragment = new DocumentFragment();
Examples
This example creates a list of major web browsers in a DocumentFragment
, then adds the new DOM subtree to the document to be displayed.
HTML
html
<ul id="ul"></ul>
JavaScript
js
const element = document.getElementById("ul"); // assuming ul exists
const fragment = document.createDocumentFragment();
const browsers = ["Firefox", "Chrome", "Opera", "Safari"];
browsers.forEach((browser) => {
const li = document.createElement("li");
li.textContent = browser;
fragment.appendChild(li);
});
element.appendChild(fragment);
Result
Specifications
Browser compatibility
Desktop | Mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
createDocumentFragment |
1 | 12 | 1 | 6 | ≤12.1 | 1 | 4.4 | 18 | 4 | ≤12.1 | 1 | 1.0 |
See also
© 2005–2023 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/Document/createDocumentFragment