我认为 DocumentFragment 的全部意义在于能够在不接触 DOM 的情况下构造内容,直到它准备就绪。
鉴于 DocumentFragment 不支持innerHTML
,它可能有点乏味。另一方面,一旦构建完成,通过片段本身很容易将内容添加到现有的 DOM 节点。
如果我创建一个div
而不将它添加到 DOM,我可以按照我喜欢的方式填充它,包括innerHTML
. 据我所知,它应该不会对性能产生额外的影响。
是否有一种简单的方法(即一行左右)将现有 DOM 节点的内容复制到 DocumentFragment?该过程如下所示:
var div=document.createElement('div');
var fragment=document.createDocumentFragment();
div.innerHTML='…';
// copy contents to fragment
// etc
这样我就可以两全其美了。
回答
下面是@KevBot 的答案,并入示例中:
var divTest=document.querySelector('div#test');
var html='<p>One</p><p>Two</p>';
var fragment=document.createRange().createContextualFragment(html);
divTest.appendChild(fragment);