首页 createElement与createDocumentFragment的点点区别小结

createElement与createDocumentFragment的点点区别小结

举报
开通vip

createElement与createDocumentFragment的点点区别小结createElement与createDocumentFragment的点点区别小结 与createDocumentFragment的点点区别小结页面导航: ? ? ? ? 正文内容 createElement与createDocumentFragment createElement与createDocumentFragment的点点区别小结 网上可以搜到的大部分都是说使用createDocumentFragment主要是因为避免因 createElement多次添加到document.body引起的效率问...

createElement与createDocumentFragment的点点区别小结
createElement与createDocumentFragment的点点区别小结 与createDocumentFragment的点点区别小结页面导航: ? ? ? ? 正文内容 createElement与createDocumentFragment 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); (声明:这是我google的第一个例子,并不代表对原作者有任何意见,原文地 址) 这个说法并没有错,但是并不严谨,因为像这种用法,主要还是用在目标节点 是已存在并且有一部分内容的情况下,比如上面例子中的body元素,如果目标 节点并不存在或者为空,完全可以用createElement创建一个相同的元素,操 作之后再使用一次appendChild或者replaceChild来达到相同的目的,这样也 不存在重复刷新的问题。 虽说我平时都是把两者混着用,但是还是得明白两者之间的一点区别: 第一: createElement创建的元素可以使用innerHTML,createDocumentFragment创 建的元素使用innerHTML并不能达到预期修改文档内容的效果,只是作为一个 属性而已。两者的节点类型完全不同,并且createDocumentFragment创建的元 素在文档中没有对应的标记,因此在页面上只能用js中访问到。 demo: 复制代码 代码如下: !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "; html head meta http-equiv="Content-Type" content="text/html; charset=utf-8"/ title /title ;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 第二:另一个最主要的区别就是createElement创建的元素可以重复操作,添 加之后就算从文档里面移除依旧归文档所有,可以继续操作,但是 createDocumentFragment创建的元素是一次性的,添加之后再就不能操作了 ( 说明 关于失联党员情况说明岗位说明总经理岗位说明书会计岗位说明书行政主管岗位说明书 :这里的添加并不是添加了新创建的片段,因为上面说过,新创建的片 段在文档内是没有对应的标签的,这里添加的是片段的所有子节点)。 一个对比的例子: 复制代码 代码如下: !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "; 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){ (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
本文档为【createElement与createDocumentFragment的点点区别小结】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_105949
暂无简介~
格式:doc
大小:19KB
软件:Word
页数:5
分类:生活休闲
上传时间:2018-04-15
浏览量:51