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 中 avalon綁定屬性總結(jié)
avalon是前端MVVM框架,在js中經(jīng)常會用到。這篇文章主要介紹了JavaScript 中 avalon綁定屬性總結(jié)的相關(guān)資料,需要的朋友可以參考下2016-10-10JS 實現(xiàn)倒計時數(shù)字時鐘效果【附實例代碼】
下面小編就為大家?guī)硪黄狫S 實現(xiàn)倒計時數(shù)字時鐘效果【附實例代碼】。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做一個參考。2016-03-03Javascript中判斷一個值是否為undefined的方法詳解
這篇文章給大家詳細介紹了在Javascript中如何判斷一個值是否為undefined,對大家的日常工作和學(xué)習很有幫助,下面來一起看看吧。2016-09-09使用javascript實現(xiàn)頁面定時跳轉(zhuǎn)總結(jié)篇
下面對使用JavaScript實現(xiàn)頁面定時跳轉(zhuǎn)做一下總結(jié),各種定時跳轉(zhuǎn)代碼記錄如下,希望對大家有所幫助2013-09-09