innerHTML 导致 DOM Node 不断增加。

发布于 2022-09-07 16:01:12 字数 1184 浏览 18 评论 0

图片

图片描述

相关代码
<!DOCTYPE html>
<html>
<head>
    <title>test</title>
</head>
<body>
<div id="test"></div>
<script>
    var oTest = document.getElementById('test');
    var i = 0;
    setInterval(function() {
        oTest.innerHTML = i++;
    }, 10);
</script>
</body>
</html>
描述

遇到一个页面 crash 的问题,在页面 creah 之前打印了 Chrome 的 window.performance 发现所有被使用的 js 堆栈内存(sedJSHeapSize)并没有超过当前 js 堆栈内存总大小(totalJSHeapSize)。现在怀疑是不是页面 DOM 数超过阈值导致页面 crash,发现页面中导致 DOM Nodes 不断上升的原因是使用了 innerHTML,虽然最后都被垃圾回收了,会不会因为某一次不成功的垃圾回收导致 DOM 数超过阈值。

问题

问题一: DOM Nodes 增加的原因主要是由于DOM未被回收,主要参考,但是 innerHTML 为什么会导致 DOM 节点的增加?
问题二: 如何像打印window.performance那样打印出 DOM Nodes(包括未回收的),document.getElementsByTagName("*").length只能打印出页面上现有的,我可以在页面crash前打印出该数排查页面 crash是不是由于 DOM 数超过阈值引起的

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

惟欲睡 2022-09-14 16:01:12

题主你好。

问题一:针对题主给定的代码,用chrome performance分析,不存在内存泄露的问题。而在题主给出的图中,我看到了内存即使回收后仍呈现一个上升的趋势,请题主将观测时间变长后再反馈结果。也请题主关注:该问题是否是因为浏览器插件引起的(而不是前端代码)?

另:题主问到innerHTML为什么会导致DOM节点的增加。这是DOM NODE类型:,代码源源不断地创造着DOM NODE,自然会上升(但因为没有额外的引用,按照逻辑会被gc收回,不存在内存泄露)

问题二: 参考谷歌的文档

春花秋月 2022-09-14 16:01:12

楼主最后确定原因了吗 我也是一直缓慢增加

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文