//方法一
const url = 'data:image/png;base64,xxxxx';
fetch(url)
.then(res => res.blob())
.then(blob => {
const file = new File([blob], "File name",{ type: "image/png" })
console.log('fileObj',file);
});
//方法二
function 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
});
}
//Usage example:
var file = dataURLtoFile('data:image/png;base64,xxxxxx', 'hello.txt');
console.log(file);
参考
使用 Fetch Data URLs 不同文件类型转base64后的前缀 base64图片的前缀是可以随便修改的吗? DATA URL简介及DATA URL的利弊