JS中如何將base64轉(zhuǎn)換成file
js將base64轉(zhuǎn)換成file
dataURLtoBlob(dataurl, name) {//base64轉(zhuǎn)file 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], name, { type: mime, }) },
this.dataURLtoBlob(imgDataUrl,name)//imgDataUrl是base64格式編碼 name是圖片名字
將Base64轉(zhuǎn)file對象,將圖片轉(zhuǎn)Base64
//將圖片轉(zhuǎn)換為Base64 function getImgToBase64(url,callback){ var canvas = document.createElement('canvas'), ctx = canvas.getContext('2d'), img = new Image; img.crossOrigin = 'Anonymous'; img.onload = function(){ canvas.height = img.height; canvas.width = img.width; ctx.drawImage(img,0,0); var dataURL = canvas.toDataURL('image/png'); callback(dataURL); canvas = null; }; img.src = url; } //將base64轉(zhuǎn)換為文件對象 function dataURLtoFile(dataurl, filename) { var arr = dataurl.split(','); var mime = arr[0].match(/:(.*?);/)[1]; var bstr = atob(arr[1]); var n = bstr.length; var u8arr = new Uint8Array(n); while(n--){ u8arr[n] = bstr.charCodeAt(n); } //轉(zhuǎn)換成file對象 return new File([u8arr], filename, {type:mime}); //轉(zhuǎn)換成成blob對象 //return new Blob([u8arr],{type:mime}); } //將圖片轉(zhuǎn)換為base64,再將base64轉(zhuǎn)換成file對象 getImgToBase64('images/ruoshui.png',function(data){ var myFile = dataURLtoFile(data,'testimgtestimgtestimg'); console.log(myFile); }); // 將 file 轉(zhuǎn) base64 blobToDataURL (blob, cb) { const reader = new FileReader() reader.onload = function (evt) { cb(evt.target.result) } reader.readAsDataURL(blob) },
js圖片base64轉(zhuǎn)file文件兩種方式
最近項目中需要實現(xiàn)把圖片的base64編碼轉(zhuǎn)成file文件的功能,然后再上傳至服務(wù)器。起初是直接通過new File()的方式進行轉(zhuǎn)換,在各個主流的瀏覽器基本上都支持,Android也沒問題,但是在ios系統(tǒng)埋了個坑,ios11.4以下的系統(tǒng)上傳失敗。
定位bug發(fā)現(xiàn)是new File()這個方法不兼容ios系統(tǒng),只能另辟蹊徑,最后找到一個方法就是:
將base64轉(zhuǎn)成blob ——> blob轉(zhuǎn)成file
這種方式測試通過,解決了new File()不兼容ios系統(tǒng)問題。
下面將base64轉(zhuǎn)file文件兩種方式的代碼貼出來:
1.通過new File()將base64轉(zhuǎn)換成file文件,此方式需考慮瀏覽器兼容問題。
? ? //將base64轉(zhuǎn)換為文件 ? ? dataURLtoFile: function(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 }); ?? ?}, ? ? ? ? //調(diào)用 ? ? var file = dataURLtoFile(base64Data, imgName);
2.先將base64轉(zhuǎn)換成blob,再將blob轉(zhuǎn)換成file文件,此方法不存在瀏覽器不兼容問題。
? ? //將base64轉(zhuǎn)換為blob ? ? dataURLtoBlob: function(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 }); ? ? }, ? ? //將blob轉(zhuǎn)換為file ? ? blobToFile: function(theBlob, fileName){ ? ? ? ?theBlob.lastModifiedDate = new Date(); ? ? ? ?theBlob.name = fileName; ? ? ? ?return theBlob; ? ? }, ? ? //調(diào)用 ? ? var blob = dataURLtoBlob(base64Data); ? ? var file = blobToFile(blob, imgName);
目前方法二在項目中已經(jīng)可以正常使用。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Bootstrap編寫一個兼容主流瀏覽器的受眾巨幕式風格頁面
這篇文章主要介紹了Bootstrap編寫一個兼容IE8、谷歌等主流瀏覽器的受眾巨幕式風格頁面,感興趣的小伙伴們可以參考一下2016-07-07JavaScript實現(xiàn)彈出DIV層同時頁面背景漸變成半透明效果
這篇文章主要介紹了JavaScript實現(xiàn)彈出DIV層同時頁面背景漸變成半透明效果,涉及JavaScript彈出窗口的實現(xiàn)及頁面元素屬性動態(tài)變換的相關(guān)技巧,需要的朋友可以參考下2016-03-03使用do...while的方法輸入一個月中所有的周日(實例代碼)
下面小編就為大家?guī)硪黄褂胐o...while的方法輸入一個月中所有的周日(實例代碼)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07js插件dropload上拉下滑加載數(shù)據(jù)實例解析
這篇文章主要為大家詳細解析了js插件dropload上拉下滑加載數(shù)據(jù)實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-07-07微信內(nèi)置瀏覽器私有接口WeixinJSBridge介紹
這篇文章主要介紹了微信內(nèi)置瀏覽器私有接口WeixinJSBridge介紹,本文講解了發(fā)送給好友、分享函數(shù)、隱藏工具欄、隱藏三個點按鈕等功能,需要的朋友可以參考下2015-05-05