我试图在获得它之前在画布上绘制图像dataURL()
,但返回的数据就像空的一样。
当我在控制台中检查它时,我看到A
字符串中有很多:( "data:image/png;base64,iVBO..some random chars... bQhfoAAAAAAAAAA... a lot of A ...AAAASUVORK5CYII="
)
当我尝试将画布附加到文档时,也没有绘制任何内容,并且我没有在控制台中抛出任何错误。
这里有什么问题 ?
这是我的代码:
var img = new Image();
img.src = "http://somerandomWebsite/picture.png";
var canvas = document.createElement('canvas');
canvas.width = img.width;
canvas.height = img.height;
var context = canvas.getContext('2d');
context.drawImage(img, 0,0); // this doesn't seem to work
var dataURL = canvas.toDataURL(); // this will give me a lot of "A"
doSomething(dataURL);
此外,在进行快速刷新时,图像会正确绘制到画布上,但我在控制台中收到一条错误消息并且dataURL
为空。
Firefox 中的消息是:“SecurityError:操作不安全。” ,
在 Chrome 中,它是“未捕获的安全错误:无法在 'HTMLCanvasElement' 上执行 'toDataURL':受污染的画布可能无法导出。” ,
而在 IE 上,我只会收到"SecurityError"。
这是什么意思 ?