JS中將圖片base64轉(zhuǎn)file文件的兩種方式
最近項目中需要實現(xiàn)把圖片的base64編碼轉(zhuǎn)成file文件的功能,然后再上傳至服務(wù)器。
1.通過new File()將base64轉(zhuǎn)換成file文件,此方式需考慮瀏覽器兼容問題
=====================1,把base64編碼轉(zhuǎn)為文件對象==========================
第一個參數(shù)dataUrl是一個base64的字符串。第二個參數(shù)是文件名可以隨意命名
funtion base64toFile(dataurl, filename = 'file') {
let arr = dataurl.split(',');
let mime = arr[0].match(/:(.*?);/)[1];
// suffix是該文件的后綴
let suffix = mime.split('/')[1];
// atob 對經(jīng)過 base-64 編碼的字符串進行解碼
let bstr = atob(arr[1]);
// n 是解碼后的長度
let n = bstr.length;
// Uint8Array 數(shù)組類型表示一個 8 位無符號整型數(shù)組 初始值都是 數(shù)子0
let u8arr = new Uint8Array(n);
// charCodeAt() 方法可返回指定位置的字符的 Unicode 編碼。這個返回值是 0 - 65535 之間的整數(shù)
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
// new File返回File對象 第一個參數(shù)是 ArraryBuffer 或 Bolb 或Arrary 第二個參數(shù)是文件名
// 第三個參數(shù)是 要放到文件中的內(nèi)容的 MIME 類型
return new File([u8arr], `${filename}.${suffix}`, {
type: mime,
});
},2.先將base64轉(zhuǎn)換成blob,再將blob轉(zhuǎn)換成file文件,此方法不存在瀏覽器不兼容問題
methods:{
//1,先將base64轉(zhuǎn)換為blob
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 });
},
//2,再將blob轉(zhuǎn)換為file
blobToFile(theBlob, fileName){
theBlob.lastModifiedDate = new Date(); // 文件最后的修改日期
theBlob.name = fileName; // 文件名
return new File([theBlob], fileName, {type: theBlob.type, lastModified: Date.now()});
},
}vue中配合vant的uploader上傳組件使用案例:
/* 單個文件上傳案例 */
afterRead(file) {
// 1.先轉(zhuǎn)為 blob格式 file.content是此文件的base64格式
let blob = this.dataURLtoBlob(file.content);
// 拿到文件名
let fileName = file.file.name;
// 2,在轉(zhuǎn)為 file類型
let file1 = this.blobToFile(blob,fileName);
console.log("file1:",file1);
// 3,上傳...
},打印結(jié)果如下:

到此這篇關(guān)于JS中圖片base64轉(zhuǎn)file文件的兩種方式的文章就介紹到這了,更多相關(guān)js 圖片base64轉(zhuǎn)file文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript必看的10道面試題總結(jié)(推薦)
JavaScript 已經(jīng)成為全棧開發(fā)技能的基石,在全棧開發(fā)面試中都會不可避免地涉及到與 JavaScript 有關(guān)的問題。這篇文章主要給大家介紹了關(guān)于JavaScript必看的10道面試題,需要的朋友可以參考下2021-05-05
部分網(wǎng)站允許空白referer的防盜鏈圖片的js破解代碼
主要是有些網(wǎng)站的圖片調(diào)用是防盜鏈的但一般只是判斷referer是不是自己網(wǎng)站,如果referer為空也會顯示圖片,所以有了下面的代碼。2011-05-05
前端實現(xiàn)下載文件(包含壓縮包下載)方式詳細總結(jié)
這篇文章主要給大家介紹了關(guān)于前端實現(xiàn)下載文件(包含壓縮包下載)方式的相關(guān)資料,這段時間項目需要下載文件,所以這里給大家總結(jié)下,需要的朋友可以參考下2023-09-09
javascript宿主對象之window.navigator詳解
這篇文章主要為大家詳細介紹了javascript宿主對象之window.navigator,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09
ExtJs使用自定義插件動態(tài)保存表頭配置(隱藏或顯示)
這篇文章主要介紹了ExtJs使用自定義插件動態(tài)保存表頭配置(隱藏或顯示) ,需要的朋友可以參考下2018-09-09
JavaScript實現(xiàn)漢字轉(zhuǎn)換為拼音的庫文件示例
這篇文章主要介紹了JavaScript實現(xiàn)漢字轉(zhuǎn)換為拼音的庫文件,結(jié)合具體實例分析了JSPinyin庫文件與簡單使用技巧,需要的朋友可以參考下2016-12-12

