我的网站突然开始崩溃Internet Explorer。
网站加载并开始执行javascript,但机器爆炸的某处。我甚至没有得到脚本错误,它只是崩溃。我试图用内置的调试器手动遍历每一行js,但当然问题不会发生。
如果我选择在崩溃时调试应用程序,我会看到以下消息。
iexplore.exe中0x6c5dedf5处的未处理异常:0xC0000005:访问冲突读取位置0x00000090。
调用堆栈中的前5项看起来像这样
VGX.DLL!6c5dedf5()
[下面的框架可能不正确和/或缺失,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。叹息
答案 0 :(得分:4)
(旧问题,但重要的一个)
我有一个非常类似的问题 - 包括许多复杂的VML(来自Raphael),看起来几乎不可能调试。
实际上,事实证明,最简单的低技术方法是最好的。这是一个显而易见的方法:我在这里写作是因为有时候面对一个令人生畏的问题时,明显的,简单的解决方案是人们想到的最后一个。
所以,简单的老派调试:在我的代码中的每个远程要求或复杂调用之前和之后有很多alert("1");
,alert("2");
等,提供不依赖于的超简单可靠断点任何可能会崩溃的功能(例如开发人员工具)。然后,只需看到它崩溃之前得到的号码警报 - 该警报与下一个警报之间必然会出现问题。
添加更多提醒,直到您将其缩小到确切的行。在我的情况下,它实际上与复杂的VML无关 - 它是一个for循环,由于某种原因只在IE7上无限延续。
答案 1 :(得分:1)
停止使用VML?
如果您在IE中需要通过移动,缩放,裁剪和替换图像而无法完成的内容,请考虑使用Flash,Silverlight或类似内容。
如果你的生活依赖于VML,那么尽可能多地阅读其他人的经历,这可能会减轻试错方法。
答案 2 :(得分:1)
它是一个空指针取消引用不可利用的崩溃
答案 3 :(得分:0)
确保在DOMReady事件发生后您的脚本正在运行。 IE在完全加载之前修改DOM时会因崩溃而臭名昭着。
答案 4 :(得分:0)
您是否以任何形式使用JSONP?像jQuery这样的流行实现倾向于尝试通过在运行后从DOM中删除脚本节点来清理内存。在很多情况下,我已经看到崩溃Internet Explorer。从来没有弄清楚需要什么其他条件来导致崩溃。我的其他页面发生的事情太多了。
无论如何,如果你正在使用jQuery.getJSON,请检查jquery源代码中的以下行: (jquery 1.4.3第5556行):
} else {
// Garbage collect
window[ jsonp ] = undefined;
try {
delete window[ jsonp ];
} catch( jsonpError ) {}
}
if ( head ) {
head.removeChild( script );
}
您可以安全地删除它,或将其条件化仅发生在非IE浏览器中。 希望这会有所帮助。