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

相关推荐
努力努力再努力dyx4 分钟前
【无标题】
开发语言·python
傻小胖10 分钟前
Object.defineProperty() 完整指南
开发语言·前端·javascript
hong16168817 分钟前
TypeScript类型断言
linux·javascript·typescript
xyx-3v18 分钟前
qt创建新工程
开发语言·c++·qt
小陈工26 分钟前
Python Web开发入门(十六):前后端分离架构设计——从“各自为政”到“高效协同”
开发语言·前端·数据库·人工智能·python
BUG_Jia35 分钟前
Vue 3 组件封装与使用:保姆级教程
前端·javascript·vue.js
前进的李工39 分钟前
MySQL用户管理与权限控制指南(含底层架构说明)
开发语言·数据库·sql·mysql·架构
思成Codes41 分钟前
从本质看:Vue3 为什么运用 LIS 算法
javascript·vue.js
少司府44 分钟前
C++基础入门:类和对象(中)
c语言·开发语言·c++·类和对象·运算符重载·默认成员函数