- 浏览: 23953 次
- 性别:
- 来自: 吉林
最新评论
-
zhangfan1990:
楼主的文章有启发啊
JavaScript原型链 -
s2640226szm:
写的不错,理解了原型链
JavaScript原型链
在DOM操纵里,createElement是创建一个新的节点,createDocumentFragment是创建一个文档片段。
网上可以搜到的大项目组都是说应用createDocumentFragment主如果因为避免因createElement多次添加到document.body引起的效力题目,比如:
这个说法并没有错,然则并不严谨,因为像这种用法,首要还是用在目标节点是已存在并且有一项目组内容的景象下,比如上方例子中的body元素,若是目标节点并不存在或者为空,完全可以用createElement创建一个雷同的元素,操纵之后再应用一次appendChild或者replaceChild来达到雷同的目标,如许也不存在反复刷新的题目。
虽说我日常平凡都是把两者混着用,然则还是得熟悉打听两者之间的一点差别:
第一:
createElement创建的元素可以应用innerHTML,createDocumentFragment创建的元素应用innerHTML并不克不及达到预期批改文档内容的结果,只是作为一个属性罢了。两者的节点类型完全不合,并且createDocumentFragment创建的元素在文档中没有对应的标识表记标帜,是以在页面上只能用js中接见到。
demo:
第二:另一个最首要的差别就是createElement创建的元素可以反复操纵,添加之后就算从文档里面移除依旧归文档所有,可以持续操纵,然则createDocumentFragment创建的元素是一次性的,添加之后再就不克不及操纵了(申明:这里的添加并不是添加了新创建的片段,因为上方说过,新创建的片段在文档内是没有对应的标签的,这里添加的是片段的所有子节点)。
一个对比的例子:
来源:http://www.mysjtu.com/page/M0/S660/660001.html
END
网上可以搜到的大项目组都是说应用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);
这个说法并没有错,然则并不严谨,因为像这种用法,首要还是用在目标节点是已存在并且有一项目组内容的景象下,比如上方例子中的body元素,若是目标节点并不存在或者为空,完全可以用createElement创建一个雷同的元素,操纵之后再应用一次appendChild或者replaceChild来达到雷同的目标,如许也不存在反复刷新的题目。
虽说我日常平凡都是把两者混着用,然则还是得熟悉打听两者之间的一点差别:
第一:
createElement创建的元素可以应用innerHTML,createDocumentFragment创建的元素应用innerHTML并不克不及达到预期批改文档内容的结果,只是作为一个属性罢了。两者的节点类型完全不合,并且createDocumentFragment创建的元素在文档中没有对应的标识表记标帜,是以在页面上只能用js中接见到。
demo:
<!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>
第二:另一个最首要的差别就是createElement创建的元素可以反复操纵,添加之后就算从文档里面移除依旧归文档所有,可以持续操纵,然则createDocumentFragment创建的元素是一次性的,添加之后再就不克不及操纵了(申明:这里的添加并不是添加了新创建的片段,因为上方说过,新创建的片段在文档内是没有对应的标签的,这里添加的是片段的所有子节点)。
一个对比的例子:
<!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>
来源:http://www.mysjtu.com/page/M0/S660/660001.html
END
发表评论
-
js 垃圾回收
2012-10-06 11:42 933在IE浏览器下可以由JS程序调用垃圾回收函数CollectGa ... -
open-flash-chart 2
2012-09-22 22:40 803最近研究了open-flash-chart2这个报表组件,组件 ... -
一段优美的正则
2012-09-08 20:42 1303记录下来,一段优美的 ... -
原生的DOM选择器
2012-09-08 15:38 3141说说下面几个方法: getElementById, getEl ... -
IE 中的id 与name
2012-09-07 16:09 2106火星浏览器(IE)又抽风了表现如下,在IE7下,使用docum ... -
compareDocumentPosition与contains
2012-09-07 13:26 1677研究KISSY 1.3RC源代码DOM/traversal 发 ... -
tabindex
2012-09-06 17:26 0http://www.cnblogs.com/rubylouv ... -
IE的href 设值BUG
2012-09-06 17:21 1355今天研究KISSY1.3 RC源代码时看到这样一段代码,如下: ... -
IE下的条件编译
2012-09-06 14:24 988在IE浏览器下,可以把部分只针对IE的javascript代码 ... -
判断IE5~IE7
2012-09-06 14:17 0判断IE5~7可以通过检测:document.document ... -
property 和attribute
2012-09-06 13:22 0aaaasdfaaaaa -
KISSY1.3.0RC源码分析一Kissy.js
2012-08-25 18:28 0kissy.js从名字即可以看出它是kissy框架最核心的文件 ... -
javascript闭包
2011-08-22 19:44 972javascript的闭包特性非常强大,但也常常成为bug的滋 ... -
javascript作用域
2011-08-22 19:37 754今天看到一篇非常帮的文章,博主仅使用几个例子就将javascr ... -
框架结构锁屏实现
2011-08-22 19:30 1867如果大家不知道什么是锁屏,可以去163信箱看一看,用途是你 ... -
SWFObject
2011-08-04 16:17 919SWFObject: 基于Javascript的Flash媒体 ... -
TrimQuery
2011-08-04 12:58 1385TrimQuery引擎是TrimPath开源项目 ... -
JavaScript原型链
2011-07-29 16:18 1572声明,文章中用到的专业名词可能并不标准。请同学指正。 ...
相关推荐
网上可以搜到的大部分都是说使用createDocumentFragment主要是因为避免因createElement多次添加到document.body引起的效率问题,比如: 代码如下: var arrText=[“1″,”2″,”3″,”4″,”5″,”6″,”7″,”8″,”...
03_createElement写法.html
//定义方法创建一个label标签 //*************************************// 代码如下: var createLabel = function(id, name, value) { var label_var = document.createElement(“label”); var label_id = document...
本文将详细介绍JavaScript中利用`createElement`创建DOM元素的两种常见方式,并探讨它们之间的区别与应用场景。 #### 一、`createElement`基本概念 `createElement`是`Document`对象的一个方法,用于创建一个指定...
### JavaScript性能优化之创建文档碎片(document.createDocumentFragment) 在探讨`document.createDocumentFragment()`方法之前,我们首先需要理解浏览器在处理DOM(文档对象模型)节点插入时的基本行为。DOM是HTML...
`document.createDocumentFragment()`是JavaScript中的一个非常有用的API,它允许开发者在不实际修改DOM树的情况下构建和操作一组节点。这个方法返回一个无父节点的`DocumentFragment`对象,可以被视为一个临时的、...
JS写图层方法.document.createElement(div).
首先,创建一个`canvas`元素,然后设置其宽度和高度(与SVG相同),最后在画布上绘制图像: ```javascript const canvas = document.createElement('canvas'); canvas.width = img.width; canvas.height = img....
JSX的编译过程会转换为`React.createElement`调用,所以两者在运行时的性能并无显著差别。但JSX的编写效率通常更高,因为它提供了更直观的代码结构。 在某些场景下,可能需要避免使用JSX,例如在不支持JSX的环境中...
在探讨JavaScript编程时,`createElement` 事件是一个核心概念,它是HTML与W3C DOM对象模型交互的基础。在浏览器端,我们可以通过JavaScript动态地创建新的HTML元素,并将其添加到网页文档中,而`createElement` 是...
总之,`docrel`是一个针对`document.createElement`的增强工具,它通过提供更丰富的API和更简洁的语法,帮助开发者更轻松地创建和管理DOM元素,从而改善了JavaScript中的元素创建过程。如果你在日常工作中频繁处理...
babel-plugin-transform-react-createelement-to-jsx 将React.createElement调用转换回JSX语法。 这对于转换开始时认为“我们不需要臭臭的编译器”的项目将已经编译的JS转换成可维护的东西(例如语法→ →→ react-...
它通常与其他DOM操作方法如`appendChild()`或`insertBefore()`一起使用。 `appendChild()`方法用于在指定节点的子节点列表末尾添加新的子节点。当调用`appendChild()`时,新创建的元素将被插入到父节点的最后,成为...
document.createDocumentFragment()说白了就是为了节约使用DOM。每次JavaScript对DOM的操作都会改变页面的变现,并重新刷新整个页面,从而消耗了大量的时间。为解决这个问题,可以创建一个文档碎片,把所有的新节点...
然而,这种做法在Firefox以及其他遵循W3C标准的浏览器中并不被支持,它们只接受不带属性的标签名,例如`document.createElement('table')`。这导致了在不同浏览器间创建元素时的不一致性。 为了解决这个问题,...
docrel document.createElement稍好一点。docrel是document.createElement的瘦包装,使元素的创建更加容易。 它还有助于清理代码并避免重复。 没有依赖关系,没有blac docrel稍微好一点的document.createElement ...
此外,IE还支持一种特殊语法,即一次性定义所有属性,如 `var e = document.createElement("<input type='radio' name='r' value='1' />");`,但这在其他浏览器中可能不工作,因此应避免使用。 为了确保跨浏览器...
obj = document.createElement(tag)创建一个标签,oParent.appendChild(obj)和oParent.insertBefore(obj,element)都是由要插入的标签的父节点调用,appendChild将创建的元素依次加在后面,而insertBefore则可以将...
在探讨“createElement”和“onclick”这两个JavaScript中的重要概念之前,我们首先需要理解它们分别代表了什么含义,以及它们在实际编程中的应用。 createElement是JavaScript中一个非常核心的方法,属于document...