如何等待onload事件在JavaScript中完成其工作

How to wait until onload event completes its work in JavaScript?

本文关键字:JavaScript 工作 事件 何等待 等待 onload      更新时间:2023-09-26

我正在使用HTML5画布开发一个打印工具。作为测试,我尝试在画布上绘制一个图像和一个矩形,然后使用下面的代码将其复制到一个新窗口进行打印,但在新窗口中我得到的只是一个空白页。

<!DOCTYPE HTML>
<html>
<head>
</head>
  <body>
   <canvas id="pageCanvas"></canvas>
    <script type="text/javascript">
    var canvas = document.getElementById("pageCanvas");
    canvas.height="700";
    canvas.width="1000";
    var ctx = canvas.getContext("2d");
    var imageData="";
    var imageObj = new Image();
    imageObj.src = imageData;
    imageObj.addEventListener("load", function() {
            ctx.drawImage(imageObj, 50, 100,1000,600);
            ctx.beginPath();
            ctx.rect(100, 101, 200, 100);
            ctx.lineWidth = 7;
            ctx.strokeStyle = 'black';
            ctx.stroke();
    }, false);
    var printWindow = window.open('');
    printWindow.document.write('<html><BODY>');
    printWindow.document.write('<center>');
    printWindow.document.write('<img src="' + canvas.toDataURL()+'"/>');
    printWindow.document.write('</center></body></html>');
    printWindow.document.close();
    printWindow.print();
    </script>
  </body>
</html>

你能指导我克服这个问题吗?

load事件处理程序附加到图像之后,在处理程序真正有机会执行之前,您正在打开新窗口,并试图立即将画布的内容复制到它上。

只需将所有以var printWindow = window.open('');开始的JS代码移动到事件处理程序中,它就可以工作了。

哦,请缩进您的代码,尤其是如果您希望其他人阅读它。


附录:如果你想等到加载了多个图像,最简单的方法是统计加载事件,并在所有事件都启动时调用一个函数,如下所示:

var imageURLs = [ ... image URLs here ... ];
var imageObjs = [];
var imagesLoaded = 0;
for (var i = 0; i < imageURLs.length; i++) {
    var image = new Image();
    image.addEventListener( "load", function() {
        imagesLoaded++;
        if (imagesLoaded == imageURLs.length) allImagesLoaded();
    } );
    image.src = imageURLs[i];
    imageObjs.push(image);
}
function allImagesLoaded() {
    // now do something with imageObjs
};

你也可以随心所欲地玩ES6承诺之类的东西,但最终的结果是一样的。

另请参阅:

  • 我可以同步多个图像加载调用吗
  • Javascript-等待加载图像