低效的DOM操作(js的问题)

使用 JavaScript 操作DOM(即添加、修改和删除元素)是相对容易,但操作效率却不怎么样。

比如,每次添加一系列DOM元素。添加一个DOM元素是一个昂贵的操作。连续添加多个DOM元素的代码是低效的。

当需要添加多个DOM元素时,一个有效的替代方法是使用 document fragments来代替,从而提高效率和性能。

html 复制代码
var div = document.getElementsByTagName("my_div");
	
var fragment = document.createDocumentFragment();

for (var e = 0; e < elems.length; e++) {  // elems previously set to list of elements
    fragment.appendChild(elems[e]);
}
div.appendChild(fragment.cloneNode(true));

除了这种方法固有的效率提高外,创建附加的DOM元素是很昂贵的,而在分离的情况下创建和修改它们,然后再将它们附加上,就会产生更好的性能。

相关推荐
老鱼说AI9 分钟前
《深入理解计算机系统》(CSAPP)2.2:整数数据类型与底层机器级表示
开发语言·汇编·算法·c#
Albert Edison13 分钟前
【ProtoBuf 语法详解】oneof 类型
开发语言·c++·protobuf
紫_龙15 分钟前
最新版vue3+TypeScript开发入门到实战教程之watch详解
前端·javascript·typescript
文公子WGZ17 分钟前
将java 21切换成java 25
java·开发语言
一直都在57217 分钟前
Java序列化和反序列化
java·开发语言
okra-22 分钟前
Axure RP 10 进阶指南:从全局变量到JavaScript语法,打造高效原型设计!
javascript·axure·photoshop
2401_8319207438 分钟前
C++与Qt图形开发
开发语言·c++·算法
重庆兔巴哥41 分钟前
如果Java环境变量配置不成功,应该怎么办?
java·开发语言
默默学前端1 小时前
ES6模板语法与字符串处理详解
前端·ecmascript·es6
良木生香1 小时前
【C++初阶】:C++入门相关知识(3):引用 & inline内联函数 & nullptr相关概念
开发语言·c++