Created
May 20, 2022 22:41
-
-
Save daisycamber/4ae5bf07a693b263256d42ad8becb101 to your computer and use it in GitHub Desktop.
Compression of strings using using blobs in JavaScript.
This file contains 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
var zip = new JSZip(); | |
function en(text, callback){ | |
var thefile = zip.file("file.zip", text); | |
var reader = new FileReader(); | |
reader.onload=callback // e.target.result | |
thefile.generateAsync({ type: "blob" }).then(function (content) { | |
reader.readAsDataURL(content); | |
}); | |
} | |
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); | |
var ia = new Uint8Array(ab); | |
for (var i = 0; i < byteString.length; i++) { | |
ia[i] = byteString.charCodeAt(i); | |
} | |
//Old Code | |
//write the ArrayBuffer to a blob, and you're done | |
//var bb = new BlobBuilder(); | |
//bb.append(ab); | |
//return bb.getBlob(mimeString); | |
//New Code | |
return new Blob([ab], {type: mimeString}); | |
} | |
function de(text, callback){ | |
zip.loadAsync(dataURItoBlob(text), {type: "blob"}).then(function (zip) { | |
Object.keys(zip.files).forEach(function (filename) { | |
zip.files[filename].async('string').then(function (fileData) { | |
callback(fileData); | |
}) | |
}) | |
}) | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment