JS技巧使用DocumentFragment加快DOM渲染速度
2011-11-01 12:12
441 查看
JS中提供了一个DocumentFragment的机制,相信大家对这个并不陌生,它可以提供一个缓冲的机制,将DOM节点先放到内存中,当节点都构造完成后,再将DocumentFragment对象添加到页面中,这时所有的节点都会一次渲染出来,这样就能减少浏览器很多的负担,明显的提高页面渲染速度。例如下面的代码:
function CreateNodes(){
for(var i =0;i <10000;i ){
var tmpNode = document.createElement("div");
tmpNode.innerHTML ="test" i " <br />";
document.body.appendChild(tmpNode);
}
}
function CreateFragments(){
var fragment = document.createDocumentFragment();
for(var i =0;i <10000;i ){
var tmpNode = document.createElement("div");
tmpNode.innerHTML ="test" i "<br />";
fragment.appendChild(tmpNode);
}
document.body.appendChild(fragment);
}
上面的代码给出了两个函数,分别是用普通的DOM方法和DocumentFragement两种方式向页面添加一万个div节点,大家可以自己实验一下,使用第二种方式要比第一种快很多。这里只是简单的div标签的平铺添加,如果是更加复杂的HTML标签或是多层的嵌套标签,那么性能的差距就会更加明显。
通过上面的例子,大家在开发JavaScript应用的时候,如果遇到这种大量节点的情况,不妨将DocumentFragment作为一个备选的方案。
function CreateNodes(){
for(var i =0;i <10000;i ){
var tmpNode = document.createElement("div");
tmpNode.innerHTML ="test" i " <br />";
document.body.appendChild(tmpNode);
}
}
function CreateFragments(){
var fragment = document.createDocumentFragment();
for(var i =0;i <10000;i ){
var tmpNode = document.createElement("div");
tmpNode.innerHTML ="test" i "<br />";
fragment.appendChild(tmpNode);
}
document.body.appendChild(fragment);
}
上面的代码给出了两个函数,分别是用普通的DOM方法和DocumentFragement两种方式向页面添加一万个div节点,大家可以自己实验一下,使用第二种方式要比第一种快很多。这里只是简单的div标签的平铺添加,如果是更加复杂的HTML标签或是多层的嵌套标签,那么性能的差距就会更加明显。
通过上面的例子,大家在开发JavaScript应用的时候,如果遇到这种大量节点的情况,不妨将DocumentFragment作为一个备选的方案。
相关文章推荐
- JavaScript Tips - 使用DocumentFragment加快DOM渲染速度
- 使用DocumentFragment加快DOM渲染速度
- JavaScript Tips 使用DocumentFragment加快DOM渲染速度
- JavaScript Tips 使用DocumentFragment加快DOM渲染速度
- 加快页面加载速度的解决方案-asp.net使用httphandler打包多CSS或JS文件
- asp.net使用httphandler打包多CSS或JS文件以加快页面加载速度
- js中迭代元素特性与DOM中的DocumentFragment类型
- asp.net使用httphandler打包多CSS或JS文件以加快页面加载速度
- 使用会声会影X3加快渲染速度的一些经验
- asp.net使用httphandler打包多CSS或JS文件以加快页面加载速度
- 使用会声会影X3加快渲染速度的一些经验
- js创建dom节点之最容易被忽略的createDocumentFragment()方法
- js中迭代元素特性与DOM中的DocumentFragment类型 笔记
- asp.net使用httphandler打包多CSS或JS文件以加快页面加载速度
- 使用createDocumentFragment的渲染数据(节省性能)
- asp.net使用httphandler打包多CSS或JS文件以加快页面加载速度
- 10 个优化技巧加快你的 Node.js 应用运行速度
- riot.js教程【三】访问DOM元素、使用jquery、mount输入参数、riotjs标签的生命周期
- Php Xml解析之DOMDocument使用方法浅解
- js字符串转换成xml对象并使用技巧解读