我有一个带有文件输入字段的网页。我想,
此过程适用于Google Chrome,但不适用于Mozilla Firefox。当我在console.log中显示canvas.toDataURL输出时

这不是正确的输出。如何从画布生成跨浏览器DataURL。
这是我的代码。
$scope.importImageForBackground = function (event)
{
$scope.file = event.target.files[0];
var img = document.createElement("img");
var reader = new FileReader();
reader.onloadend = function (e) {
$scope.$apply(function () {
img.src = e.target.result;
var canvas = document.createElement("canvas");
var ctx = canvas.getContext("2d");
canvas.width = 1050;
canvas.height = 600;
ctx.drawImage(img, 0, 0, 1050, 600);
$scope.data = canvas.toDataURL("image/png");
console.log($scope.data);
});
};
reader.readAsDataURL($scope.file);
};
答案 0 :(得分:4)
等待图片加载。
img.onload = function(){
var canvas = ...
};
img.src = e.target.result;
请注意,这是@ kaiido评论的副本粘贴,因为他拒绝将其作为答案重新发布。归功于他。
答案 1 :(得分:0)
我遇到了同样的问题,您可以使用下面显示的Javascript修复此问题
fetchmessage.then(result => this.props.inboxStore.inboxMessageFetch(mobileNumber, firebaseToken));