来自 DataURL 的 Blob?

新手上路,请多包涵

使用 FileReaderreadAsDataURL() 我可以将任意数据转换为数据 URL。有没有办法使用内置浏览器 api 将数据 URL 转换回 Blob 实例?

原文由 Shane Holloway 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 390
2 个回答

用户 Matt 在一年前提出了以下代码( How to convert dataURL to file object in javascript? )这可能对你有帮助

编辑:正如一些评论者所报告的,BlobBuilder 已在一段时间前被弃用。这是更新后的代码:

 function dataURItoBlob(dataURI) {
  // convert base64 to raw binary data held in a string
  // doesn't handle URLEncoded DataURIs - see SO answer #6850276 for code that does this
  var byteString = atob(dataURI.split(',')[1]);

  // separate out the mime component
  var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]

  // write the bytes of the string to an ArrayBuffer
  var ab = new ArrayBuffer(byteString.length);

  // create a view into the buffer
  var ia = new Uint8Array(ab);

  // set the bytes of the buffer to the correct values
  for (var i = 0; i < byteString.length; i++) {
      ia[i] = byteString.charCodeAt(i);
  }

  // write the ArrayBuffer to a blob, and you're done
  var blob = new Blob([ab], {type: mimeString});
  return blob;

}

原文由 devnull69 发布,翻译遵循 CC BY-SA 3.0 许可协议

像@Adria 方法,但使用 Fetch api 和更小的 [ caniuse? ]

不必考虑 mimetype,因为 blob 响应类型开箱即用

警告:可能违反内容安全策略 (CSP)

…如果你使用那些东西

 var url = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg=="

fetch(url)
.then(res => res.blob())
.then(blob => console.log(blob))

不要认为你可以在不使用 lib 的情况下做得比这更小

原文由 Endless 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题