javascript – 我的网站不断崩溃IE,无法调试

前端之家收集整理的这篇文章主要介绍了javascript – 我的网站不断崩溃IE,无法调试前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个网站,突然开始崩溃Internet Explorer.

网站加载并开始执行javascript,但在某处机器爆炸.我甚至没有得到脚本错误,它只是崩溃.我试图用内置的调试器手动遍历每一行js,但当然问题不会发生.

如果我选择在崩溃时调试应用程序,我会看到以下消息.

iexplore.exe中0x6c5dedf5处的未处理异常:0xC0000005:访问冲突读取位置0x00000090.

调用堆栈中的前5项看起来像这样

VGX.dll!6c5dedf5()
[Frames below may be incorrect and/or missing,no symbols loaded for VGX.dll]
VGX.dll!6c594d70()
VGX.dll!6c594f63()
VGX.dll!6c595350()
VGX.dll!6c58f5e3()
mshtml.dll!6f88dd17()

VGX.dll似乎是vml渲染器的一部分,我实际上使用的是VML.我并不感到惊讶,因为我有很多vml的问题,属性必须按特定的顺序设置,有时你不能设置属性,当你有元素附加到dom或反之亦然(一切没有文档btw)但然后问题通常可以在调试时重现,但现在不能:(

没有插件模式也会出现此问题.

有没有比试验和错误更好的方法解决这个问题?

编辑:
添加一个控制台输出每个可疑的修改到DOM使得问题有时只发生. (控制台也在同一页面的javascript中实现,我甚至可以在崩溃后看到输出,因为窗口仍然可见)显然它似乎是某种竞争条件.

我设法进一步跟踪它,并且它似乎发生在刚刚添加后从DOM中删除对象太快. (最有可能只对具有一些特殊属性的vml元素,没有进一步尝试)并且它无法通过在removeChild前面添加一个死循环来修复(无论如何都是非常糟糕的解决方案),页面必须由浏览器一旦在addChild之后再调用removeChild.叹

解决方法

(旧问题,但重要的一个)

我有一个非常类似的问题 – 包括许多复杂的VML(来自Raphael),它看起来几乎不可能调试.

实际上,事实证明,最简单的低技术方法是最好的.这是一个显而易见的方法:我在这里写作是因为有时候面对一个令人生畏的问题时,明显的,简单的解决方案是人们想到的最后一个.

所以,简单的老式调试:很多警报(“1”);,警报(“2”);在我的代码中的每个远程要求或复杂调用之前和之后,提供超级简单可靠的断点,这些断点不依赖于可能自身崩溃的任何功能(例如开发人员工具).然后,只需看到它崩溃之前得到的号码警报 – 该警报与下一个警报之间必然会出现问题.

添加更多警报,直到将其缩小到确切的行.在我的情况下,它实际上与复杂的VML无关 – 它是一个for循环,由于某种原因,仅在IE7上无限延续.

猜你在找的JavaScript相关文章