javascript – 组件返回失败代码:0x80040111(NS_ERROR_NOT_AVAILABLE)

前端之家收集整理的这篇文章主要介绍了javascript – 组件返回失败代码:0x80040111(NS_ERROR_NOT_AVAILABLE)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的问题 :
  1. uncaught exception: [Exception... "Component returned failure code: 0x80040111 (NS_ERROR_NOT_AVAILABLE) [nsIDOMCanvasRenderingContext2D.drawImage]" nsresult: "0x80040111 (NS_ERROR_NOT_AVAILABLE)" location: "JS frame :: file:///***************.js :: redrawView :: line 308" data: no]

产生此行为的代码(tmpImg正在动态加载,因此如果尚未加载,则跳过它).

  1. if(tmpImg!=null && tmpImg.img.complete===true && tmpImg.img.src!=null){
  2. var tmpPos = i_getCoordsImage(tmpImg);
  3. var rect = getRectInCurrentView(tmpPos.x,tmpPos.y,tmpPos.w,tmpPos.h);
  4. console.log(tmpImg);
  5. console.log(rect);
  6. mainDisplayContext.drawImage(tmpImg.img,rect.x,rect.y,rect.w,rect.h);
  7. }

当tmpImg刚刚加载(至少根据Firebug的日志),然后消失时,该问题发生几次.
代码片段被连续调用多次,所以当抛出错误时,我看不到图像是否实际显示.
rect *中的值是浮点数,像{x:-1500,y:-2500,h:1000,w:1000}

你有什么想法这个错误的起源吗?

编辑1

代码产生错误(您需要在同一目录中有一个名为“test.png”的映像

  1. <!DOCTYPE html>
  2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr">
  3. <head>
  4. <Meta charset="UTF-8" />
  5. </head>
  6. <body id="body">
  7. <canvas id="canvas" width="600" height="600"></canvas>
  8. <script>
  9. //[CDATA[
  10. var img = new Image();
  11. var mdc = document.getElementById("canvas").getContext("2d");
  12. function displayCallback(){
  13. if(img.complete===true && img.src!=null){
  14. mdc.drawImage(img,600,600);
  15. }
  16. setTimeout(displayCallback,50);
  17. }
  18. setTimeout(function(){img.src = "test.png";},10000);
  19. setTimeout(displayCallback,1000);
  20. //]]
  21. </script>
  22. </body>
  23. </html>

这似乎与空图像具有“”的src合适性有关.它总是真的吗?

编辑2

事实上,对于错误报告,这个JavaScript就足够了(如果我明白的话):

  1. document.getElementById("canvas").getContext("2d").drawImage(new Image(),0);

解决方法

当DOM API调用抛出未被捕获的JavaScript异常时,您会从Firefox获得这种无益的错误消息.执行drawImage – http://mxr.mozilla.org/mozilla-central/source/content/canvas/src/nsCanvasRenderingContext2D.cpp#3212代码似乎返回错误代码NS_ERROR_NOT_AVAILABLE(在C / JS边界时被转换为JS异常),由于某些原因,绘制图像所需的所有数据目前不在可用.似乎即使图像被认为是完全加载也可能发生这种情况;我对这部分代码不够熟悉,为什么会这样.

我认为,偶尔的Firefox内部黑客,您在浏览器中发现了一个错误specification for drawImage在任何情况下都不会使用此错误代码生成异常. (请注意行3243上的评论,似乎误解了规范说明.)请构建一个完整的,独立的测试用例来证明问题,然后我将很乐意提供一个错误报告.

猜你在找的JavaScript相关文章