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

时间:2010-10-16 12:37:29

标签: javascript internet-explorer debugging crash vml

我的网站突然开始崩溃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。叹息

5 个答案:

答案 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时会因崩溃而臭名昭着。

在某些情况下,IE可能会过早地触发DOMReady事件。请参阅有关如何克服此herehere的更多信息。

答案 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浏览器中。 希望这会有所帮助。