初识 javascript 文档碎片

今天遇到一个问题: 我通过 ajax 取回另一个页面的 Html 。但这些 HTML 我不想直接
输出,想通过 getElementsByName 处理后再输出相应的内容。用原生的 javascript
怎样可以处理呢?

后来是一技术群问到以下一段代码:

 1 function html2node(s) {
 2     var d = document.createElement('div');
 3     d.innerHTML = s;
 4     if (d.childNodes.length == 1)
 5         return d.childNodes[0];
 6     var df = document.createDocumentFragment();
 7     while (d.firstChild)
 8         df.appendChild(d.firstChild);
 9     return df;
10 }


大概的原理都明白,比较困惑的是为什么要用 document.createDocumentFragment 呢?
后来在网上搜索了一下相关资源才知道,document.createDocumentFragment 是用来创建文档碎片的。
当我们需要大量 appendChild 页面元素时,可以先将这些元素 appendChild 进 document.createDocumentFragment。
然后只需 appendChild 文档碎片到页面就可以了。这样就不用多次刷新页面达到性能优化的目的。上面那个代码
我觉得用到文档碎片是多余的。


参考资料:
《JavaScript性能优化--创建文档碎片》
posted @ 2010-07-13 09:53  chy1000  阅读(763)  评论(0编辑  收藏  举报