jsDOM批量插入节点性能测试

2021-03-03 17:26

阅读:645

标签:状态   用户   字符串拼接   document   turn   批量插入   手动   ddr   tee   

测试配置:
cpu:Intel(R) Core(TM) i7-9750H CPU @2.60GHz
gpu:GTX1650 4G
内存:DDR4 2667MHz
浏览器:Chrome 版本 87.0.4280.141

// 测试执行耗时方法
function getRunTime(fun) {
    const start = new Date().getTime();//起始时间
    fun();//执行待测函数
    const end = new Date().getTime();//结束时间
    return (end - start) + "ms";//返回函数执行需要时间
}
const body = document.body;

// 方法1:拼接字符串后innerHTML一次性添加
function strTest() {
    let str = ‘‘;
    for (let i = 0; i Test‘;
    }
    body.innerHTML = str;
}

// 方法2:数组添加值后join转字符串再innerHTML一次性添加
function arrTest() {
    const arr = [];
    for (let i = 0; i Test‘);
    }
    body.innerHTML = arr.join(‘‘);
}

// 方法3:使用DOM API插入
function domTest() {
    for (let i = 0; i 

上面的测试是分开进行的,比如测试方法1的时候会把其他代码注释掉,下面把注释全部打开同时测试:
技术图片
技术图片
技术图片
技术图片
技术图片
无论怎样测试都会发现,速度由快到慢是:方法1字符串拼接 --> 方法2数组+字符串 --> 方法3DOM API和方法4fragment文档碎片机制(方法3、4没看出来究竟谁快)
最后说一下,在测试时控制台已经输出了耗时,但页面实际并没有渲染出来,会再延迟一会儿再渲染,我又手动测试了实际耗时,实际和上面的测试结果差距不大
实际开发中一般也不会同时操作大量元素节点,再又如删除元素节点、添加元素节点在合适的场景下通过更改css的display:none等手段会更好
但现在只要项目不是老项目,基本也不会有这些问题,比如而在React中,有他自己的虚拟dom,用户在对dom的操作实际上是对虚拟dom的操作,
用户的操作产生的数据改变或者state变量改变都会应用到虚拟dom上,之后再批量的对这些更改进行diff算法计算,对比操作前后的虚拟dom树,把更改后的变化再同步到真实dom上。
也就是说在虚拟dom上执行多次修改,在真实dom中,只会执行一次dom操作,因为在React虚拟dom机制中,它会把所有的操作都合并,只会对比刚开始的状态和最后操作的状态,两者中找出不同,然后再同步到真实dom中。

jsDOM批量插入节点性能测试

标签:状态   用户   字符串拼接   document   turn   批量插入   手动   ddr   tee   

原文地址:https://www.cnblogs.com/hymenhan/p/14252577.html


评论


亲,登录后才可以留言!