在DOM节点操作中,innerTHML和createElement都可以实现创建元素。它们实现的功能类似,但是效率却相差很大。本文分别统计用innerTHML字符串拼接方式、innerTHML数组方式和createElement方式创建1000次元素的时间,来比较它们之间效率的高低。
代码:
function fn() {
var d1 = +new Date();
var str = ‘‘;
for (var i = 0; i < 1000; i++) {
document.body.innerHTML += ‘<div style="width:100px; height:2px; border:1px solid blue;"></div>‘;
}
var d2 = +new Date();
console.log(d2 - d1);
}
fn();
所用时间:
(刷新页面测试3次)
代码:
function fn() {
var d1 = +new Date();
var array = [];
for (var i = 0; i < 1000; i++) {
array.push(‘<div style="width:100px; height:2px; border:1px solid blue;"></div>‘);
}
document.body.innerHTML = array.join(‘‘);
var d2 = +new Date();
console.log(d2 - d1);
}
fn();
所用时间:
(刷新页面测试3次)
代码:
function fn() {
var d1 = +new Date();
for (var i = 0; i < 1000; i++) {
var div = document.createElement(‘div‘);
div.style.width = ‘100px‘;
div.style.height = ‘2px‘;
div.style.border = ‘1px solid red‘;
document.body.appendChild(div);
}
var d2 = +new Date();
console.log(d2 - d1);
}
fn();
所用时间:
(刷新页面测试3次)
innerTHML字符串拼接方式 >> createElement方式 > innerTHML数组方式
innerTHML数组方式 > createElement方式 > innerTHML字符串拼接方式
JavaScript innerTHML和createElement效率对比
原文:https://www.cnblogs.com/jacklzx/p/13787610.html