vue-core-image-upload icon indicating copy to clipboard operation
vue-core-image-upload copied to clipboard

Supporting dataURLtoBlob && dataURLtoFile

Open limdblur opened this issue 6 years ago • 0 comments

Recommend that before call tryAjaxUpload(callback, isBinary, base64Code) function add some condition to parse base64Code to Blob. for instance:

dataURLtoBlob (dataurl) {
    var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
    while (n--) {
        u8arr[n] = bstr.charCodeAt(n);
    }
    return new Blob([u8arr], { type: mime });
}

dataURLtoFile(dataurl, filename) {
    var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
    while(n--){
        u8arr[n] = bstr.charCodeAt(n);
    }
    return new File([u8arr], filename, {type:mime});
}

that will be nice for some server which only support blob upstream.

limdblur avatar Dec 18 '18 09:12 limdblur