-
-
Save MohammadYounes/9def2b27db9c8424666b to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
function dataURItoBlob(dataURI, callback) { | |
// 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); | |
var ia = new Uint8Array(ab); | |
for (var i = 0; i < byteString.length; i++) { | |
ia[i] = byteString.charCodeAt(i); | |
} | |
// write the ArrayBuffer to a blob, and you're done | |
var bb = new BlobBuilder(); | |
bb.append(ab); | |
return bb.getBlob(mimeString); | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
http://updates.html5rocks.com/2012/06/Don-t-Build-Blobs-Construct-Them
BlobBuilder():
Blob():
Handy! So now, instead of appending to a BlobBuilder, we can simply create the Blob from an array of data parts. The data parts can be different types (DOMString, ArrayBuffer, Blob) and in any order. For example: