低效的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元素是很昂贵的,而在分离的情况下创建和修改它们,然后再将它们附加上,就会产生更好的性能。

相关推荐
千里马-horse11 分钟前
React Native 源码分析 -- jsi.h
javascript·c++·react native·react.js·jsi
bkspiderx25 分钟前
C++中的访问控制:private、public与protected的深度解析
开发语言·c++·算法·访问控制·private·public·protected
lly20240630 分钟前
Python3 与 VSCode:高效开发环境的选择
开发语言
夏幻灵1 小时前
【Java进阶】面向对象编程第一站:深入理解类、对象与封装前言
java·开发语言
nsjqj1 小时前
JavaEE初阶:多线程(1)
java·开发语言·jvm
MoonPointer-Byte1 小时前
[特殊字符]The Omniscient Tome | 全知之书
javascript·html5
wjs20241 小时前
Bootstrap5 表单验证
开发语言
带土11 小时前
9. Qt Lambda
开发语言·qt
编程饭碗1 小时前
【Java 类的完整组成】
java·开发语言·python
DLite2 小时前
Python静态类型设计:语法割裂的槽点
开发语言·python