JavaScript - createDocumentFragment() method

revision:


Category : document

The createDocumentFragment() method creates a new empty DocumentFragment into which DOM nodes can be added to build an offscreen DOM tree.

The method creates an offscreen node, which can be used to build a new document fragment that can be insert into any document. It can also be used to extract parts of a document, change, add, or delete some of the content, and insert it back to the document.

Syntax :

        document.createDocumentFragment()
    

Parameters: none

Examples:

            const fragment = new DocumentFragment();
        

Practical examples

example: create a list of major web browsers

    code:
                        <div>
                            <ul id="ul"></ul>
                        </div>
                        <script>
                            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);
                        </script>
                    

    example: add elements to an empty list

    code:
                        <div>
                            <ul id="myList">
                            </ul>
                        </div>
                        <script>
                            const fruits = ["Banana", "Orange", "Mango"];
                            // Create a document fragment:
                            const dFrag = document.createDocumentFragment();
                            for (let x in fruits) {
                                const li = document.createElement('li');
                                li.textContent = fruits[x];
                                dFrag.appendChild(li);
                            }
                            // Add fragment to a list: 
                            document.getElementById('myList').appendChild(dFrag);
                        </script>
                    

    example: add elements to an existing list

    • Apple
    • Pear
    code:
                        <div>
                            <ul id="myList2">
                                <li>Apple</li> 
                                <li>Pear</li>
                            </ul>
                        </div>
                        <script>
                            const fruits1 = ["Banana", "Orange", "Mango"];
                            // Create a document fragment:
                            const dFrag1 = document.createDocumentFragment();
                            for (let x in fruits1) {
                                const li = document.createElement('li');
                                li.textContent = fruits1[x];
                                dFrag1.appendChild(li);
                            }
                            // Add fragment to a list: 
                            document.getElementById('myList2').appendChild(dFrag1);
                        </script>