`
ywxowen999
  • 浏览: 23960 次
  • 性别: Icon_minigender_1
  • 来自: 吉林
社区版块
存档分类
最新评论

[转]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);


这个说法并没有错,然则并不严谨,因为像这种用法,首要还是用在目标节点是已存在并且有一项目组内容的景象下,比如上方例子中的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
分享到:
评论

相关推荐

    createElement与createDocumentFragment的点点区别小结

    网上可以搜到的大部分都是说使用createDocumentFragment主要是因为避免因createElement多次添加到document.body引起的效率问题,比如: 代码如下: var arrText=[“1″,”2″,”3″,”4″,”5″,”6″,”7″,”8″,”...

    03_createElement写法.html

    03_createElement写法.html

    js 用CreateElement动态创建标签示例

    //定义方法创建一个label标签 //*************************************// 代码如下: var createLabel = function(id, name, value) { var label_var = document.createElement(“label”); var label_id = document...

    javascript中createElement的两种创建方式.docx

    本文将详细介绍JavaScript中利用`createElement`创建DOM元素的两种常见方式,并探讨它们之间的区别与应用场景。 #### 一、`createElement`基本概念 `createElement`是`Document`对象的一个方法,用于创建一个指定...

    JavaScript性能优化 创建文档碎片(document.createDocumentFragment)

    ### JavaScript性能优化之创建文档碎片(document.createDocumentFragment) 在探讨`document.createDocumentFragment()`方法之前,我们首先需要理解浏览器在处理DOM(文档对象模型)节点插入时的基本行为。DOM是HTML...

    关于javascript document.createDocumentFragment()

    `document.createDocumentFragment()`是JavaScript中的一个非常有用的API,它允许开发者在不实际修改DOM树的情况下构建和操作一组节点。这个方法返回一个无父节点的`DocumentFragment`对象,可以被视为一个临时的、...

    JS写图层方法.document.createElement(div).htm

    JS写图层方法.document.createElement(div).

    javascript将svg转图片代码组件,亲测有效;

    首先,创建一个`canvas`元素,然后设置其宽度和高度(与SVG相同),最后在画布上绘制图像: ```javascript const canvas = document.createElement('canvas'); canvas.width = img.width; canvas.height = img....

    react-ReactcreateElement和JSX替代语法糖

    JSX的编译过程会转换为`React.createElement`调用,所以两者在运行时的性能并无显著差别。但JSX的编写效率通常更高,因为它提供了更直观的代码结构。 在某些场景下,可能需要避免使用JSX,例如在不支持JSX的环境中...

    浅谈javascript中createElement事件

    在探讨JavaScript编程时,`createElement` 事件是一个核心概念,它是HTML与W3C DOM对象模型交互的基础。在浏览器端,我们可以通过JavaScript动态地创建新的HTML元素,并将其添加到网页文档中,而`createElement` 是...

    docrel更好用的documentcreateElement方法

    总之,`docrel`是一个针对`document.createElement`的增强工具,它通过提供更丰富的API和更简洁的语法,帮助开发者更轻松地创建和管理DOM元素,从而改善了JavaScript中的元素创建过程。如果你在日常工作中频繁处理...

    babel-plugin-transform-react-createelement-to-jsx:将React.createElement调用转换为JSX语法

    babel-plugin-transform-react-createelement-to-jsx 将React.createElement调用转换回JSX语法。 这对于转换开始时认为“我们不需要臭臭的编译器”的项目将已经编译的JS转换成可维护的东西(例如语法→ →→ react-...

    document.createElement()用法

    它通常与其他DOM操作方法如`appendChild()`或`insertBefore()`一起使用。 `appendChild()`方法用于在指定节点的子节点列表末尾添加新的子节点。当调用`appendChild()`时,新创建的元素将被插入到父节点的最后,成为...

    浅析document.createDocumentFragment()与js效率

    document.createDocumentFragment()说白了就是为了节约使用DOM。每次JavaScript对DOM的操作都会改变页面的变现,并重新刷新整个页面,从而消耗了大量的时间。为解决这个问题,可以创建一个文档碎片,把所有的新节点...

    使用jQuery解决IE与FireFox下createElement方法的差异

    然而,这种做法在Firefox以及其他遵循W3C标准的浏览器中并不被支持,它们只接受不带属性的标签名,例如`document.createElement('table')`。这导致了在不同浏览器间创建元素时的不一致性。 为了解决这个问题,...

    稍微好一点的document.createElement-JavaScript开发

    docrel document.createElement稍好一点。docrel是document.createElement的瘦包装,使元素的创建更加容易。 它还有助于清理代码并避免重复。 没有依赖关系,没有blac docrel稍微好一点的document.createElement ...

    document.createElement()用法及注意事项(ff下不兼容)

    此外,IE还支持一种特殊语法,即一次性定义所有属性,如 `var e = document.createElement("&lt;input type='radio' name='r' value='1' /&gt;");`,但这在其他浏览器中可能不工作,因此应避免使用。 为了确保跨浏览器...

    JavaScript:createElement和insertBefore

    obj = document.createElement(tag)创建一个标签,oParent.appendChild(obj)和oParent.insertBefore(obj,element)都是由要插入的标签的父节点调用,appendChild将创建的元素依次加在后面,而insertBefore则可以将...

    createElement和onclick

    在探讨“createElement”和“onclick”这两个JavaScript中的重要概念之前,我们首先需要理解它们分别代表了什么含义,以及它们在实际编程中的应用。 createElement是JavaScript中一个非常核心的方法,属于document...

Global site tag (gtag.js) - Google Analytics