canvas.toDataURL()生成错误的DataURL

canvas.toDataURL() generate wrong DataURL

本文关键字:错误 DataURL toDataURL canvas      更新时间:2023-09-26

我的代码中的toDataURL()函数有什么问题
我的问题是,p0画布将保持为空
dataurl.net中上传我的图像后,我发现它的DataUrl代码和我保存在LocalStorage中的DataUrl代码不同!!这就是为什么它不能显示任何东西!

<canvas id="p0" width="512" height="176" style="margin-left: 200px; margin-top: 216px; position: absolute"></canvas>
<script>
function init() {
    var p0 = document.getElementById("p0");
    var P0 = p0.getContext('2d');
    var img = new Image;
    img.onload = function () {
        P0.drawImage(img, 0, 0);
    };
    if (localStorage.getItem("version") == Version) {
        img.src = localStorage.getItem("p0");
    } else {
        localStorage.setItem("version", Version);
        img.src = "Index/2/logo.png";
        localStorage.setItem("p0", p0.toDataURL("image/png"));
    }
}
init();
</script>

感谢Bergi,
它只需要放上这行:

localStorage.setItem("p0", p0.toDataURL("image/png"));

到img.onload函数中。

img.onload = function () {
    P0.drawImage(img, 0, 0);
    localStorage.setItem("p0", p0.toDataURL("image/png"));
};