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

相关推荐
祈澈菇凉22 分钟前
什么是 Vue 的自定义事件?如何触发和监听?
前端·javascript·vue.js
a0023450011 小时前
python类型转换&深浅拷贝
开发语言·python
2301_766536052 小时前
调试无痛入手
开发语言·前端
+7202 小时前
Java 的 HttpClient 中使用 POST 请求传递参数
java·开发语言
@大迁世界3 小时前
构建 Next.js 应用时的安全保障与风险防范措施
开发语言·前端·javascript·安全·ecmascript
IT、木易4 小时前
ES6 新特性,优势和用法?
前端·ecmascript·es6
is今夕4 小时前
postcss.config.js 动态配置基准值
javascript·vue.js·postcss
水瓶丫头站住4 小时前
Qt中QRadioButton的样式设置
开发语言·qt
青茶绿梅*24 小时前
500字理透react的hook闭包问题
javascript·react.js·ecmascript