Add elements to an empty list:
const fruits = ["Banana", "Orange", "Mango"];
// Create a document fragment:
const dFrag = document.createDocumentFragment();
// Add li elements to the fragment:
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);
Try it Yourself »
Add elements to an existing list:
const fruits = ["Banana", "Orange", "Mango"];
// Create a document fragment:
const dFrag = document.createDocumentFragment();
// Add li elements to the fragment:
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);
Try it Yourself »
The createDocumentFragment()
method creates an offscreen node.
The offscreen node can be used to build a new document fragment that can be insert into any document.
The createDocumentFragment()
method 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.
You can always edit HTML elements directly. But a better way is to construct an (offscreen) document fragment, and attach this fragment to the real (live) DOM when it is ready. Because you insert the fragment when it is ready, there will be only one reflow and one single render.
If you want to append HTML elements items in a loops, using document fragments also improves performance.
Document nodes appended to the document fragment, are removed from the original document.
document.createDocumentFragment()
NONE |
Type | Description |
Node | The created DocumentFragment node. |
document.createComment()
is a DOM Level 1 (1998) feature.
It is fully supported in all browsers:
Chrome | Edge | Firefox | Safari | Opera | IE |
Yes | Yes | Yes | Yes | Yes | 9-11 |
截取页面反馈部分,让我们更快修复内容!也可以直接跳过填写反馈内容!