Firefox 不会在第一次访问时绘制到 canvas

Firefox won't draw to canvas on first visit

我有一个问题,我很难相信...当我在 Firefox 中绘制动态创建的 canvas 时,它似乎不会在源为 [=41= 的第一时间呈现]... 这似乎是第一次发生 JavaScript 问题是 运行 通过修改源代码或第一次访问 link。以下是一些重现步骤:

1) 打开一个全新的 Firefox 实例。访问下面的 jsFiddle。

2) 什么也没看到

3) 在 Firefox 中打开一个新选项卡。访问下面的 jsFiddle。

4) 查看结果(10 个彩色方块)

在 Chrome 中执行此操作将导致在第 2 步和第 4 步中看到结果。

https://jsfiddle.net/sk873txv/1/

html

<body>
    <div id="a">
    </div>
</body>

js

$(document).ready(function(){
    var make_canvas = function(i) {
        var $canvas = $('<canvas>').appendTo($('#a'));
        $canvas.attr('width', '100px');
        $canvas.attr('height', '100px');
        var canvas = $canvas[0];
        var ctx = canvas.getContext('2d');
        return ctx;
    };

    var draw = function(ctx) {
       var image = new Image();
       image.src = "";
       ctx.drawImage(image, 0, 0);
    };

    for(var i = 0; i < 10; i++)
    {
        draw(make_canvas(i));
    }

});

您应该等待 load event 在图像上触发,然后再将其绘制到 canvas。即使图像数据作为数据 URI 嵌入,也不能保证在您设置 src 时图像会被渲染并准备好绘制。等待 load 事件将确保图像准备就绪。

工作示例(JSFiddle):

$(document).ready(function(){
    var make_canvas = function(i) {
        var $canvas = $('<canvas>').appendTo($('#a'));
        $canvas.attr('width', '100px');
        $canvas.attr('height', '100px');
        var canvas = $canvas[0];
        var ctx = canvas.getContext('2d');
        return ctx;
    };
    
    var draw = function(ctx) {
       var image = new Image();
       image.onload = function() {
           ctx.drawImage(image, 0, 0);
       };
       image.src = "";
    };
    
    for(var i = 0; i < 10; i++)
    {
        draw(make_canvas(i));
    }

});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<body>
    <div id="a">
    </div>
</body>