微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – 访问canvas.ToBlob()异步函数之外的blob值

我正在使用HTMLCanvas元素,它返回异步toBlob()函数之外的blob对象.此函数不返回输出值,因此我尝试在外部声明变量并通过命令访问它.

我如何在这种情况下使用JS Promise?

var myblob;
            canvas.toBlob(function(blob) {                         
                              myblob = blob;
                              console.log("inside " + myblob); // getting value after the console outside
                           })
 console.log( "outside " + myblob); // getting undefined   

解决方法:

您可以使用Promise构造函数,将Blob实例传递给resolve(),在.then()访问Promise值

function getCanvasBlob(canvas) {
  return new Promise(function(resolve, reject) {
    canvas.toBlob(function(blob) {
      resolve(blob)
    })
  })
}

var canvasBlob = getCanvasBlob(canvas);

canvasBlob.then(function(blob) {
  // do stuff with blob
}, function(err) {
  console.log(err)
});

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐