[转]createElement与createDocumentFragment的点点差别
在DOM操纵里,createElement是创建一个新的节点,createDocumentFragment是创建一个文档片段。
网上可以搜到的大项目组都是说应用createDocumentFragment主如果因为避免因createElement多次添加到document.body引起的效力题目,比如:
var arrText=["1","2","3","4","5","6","7","8","9","10"];for(var i=0;i<arrText.length;i++){ var op=document.createElement()"P"); var oText=document.createTextNode(arrText[i]); op.appendChild(oText); document.body.appendChild(op);}var arrText=["1","2","3","4","5","6","7","8","9","10"];var oFrag=document.createDocumentFragment();for(var i=0;i<arrText.length;i++){var op=document.createElement("P"); var oText=document.createTextNode(arrText[i]); op.appendChild(oText); oFrag.appendChild(op); }document.body.appendChild(oFrag);<!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> <style type="text/css"> #outer{ height: 200px; border: 1px solid #006400;} </style></head><body><div id="outer"></div><input type="button" value="createElement" id="btn_1"/><input type="button" value="createDocumentFragment" id="btn_2"/><script type="text/javascript">var fragment_1 = document.createDocumentFragment();fragment_1.innerHTML = "<p>我是一个粉刷匠</p>";document.body.appendChild(fragment_1); var fragment_2 = document.createElement("p"); fragment_2.innerHTML = "粉刷本领强"; document.body.appendChild(fragment_2);</script></body></html><!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> <style type="text/css"> #outer{ height: 200px; border: 1px solid #006400;} </style></head><body><div id="outer"></div><input type="button" value="createElement" id="btn_1"/><input type="button" value="createDocumentFragment" id="btn_2"/><script type="text/javascript"> function $(id){ return document.getElementById(id); } var outer = $("outer");var inner = $("inner"); $("btn_1").onclick = function(){ var div = document.createElement("div");div.innerHTML = "<p>测试createElement</p>"; document.body.appendChild(div); setTimeout(function(){outer.appendChild(div);setTimeout(function(){outer.removeChild(div); },1000)},1000)} $("btn_2").onclick = function(){ var p = document.createElement('p'); p.innerHTML = "测试DocumentFragment"; var fragment = document.createDocumentFragment(); fragment.appendChild(p); fragment.innerHTML = "<p>测试DocumentFragment</p>"; fragment.innerHTML = "<span>测试DocumentFragment</span>"; document.body.appendChild(fragment); setTimeout(function(){outer.appendChild(fragment);//报错,因为此时文档内部已经可以或许不存在fragment了 setTimeout(function(){outer.removeChild(fragment); },1000) },1000) }</script></body></html>