欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS中如何將base64轉(zhuǎn)換成file

 更新時間:2023年04月17日 09:36:54   作者:前端程序猿i  
這篇文章主要介紹了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編寫一個兼容主流瀏覽器的受眾巨幕式風格頁面

    這篇文章主要介紹了Bootstrap編寫一個兼容IE8、谷歌等主流瀏覽器的受眾巨幕式風格頁面,感興趣的小伙伴們可以參考一下
    2016-07-07
  • js和jq使用submit方法無法提交表單的快速解決方法

    js和jq使用submit方法無法提交表單的快速解決方法

    下面小編就為大家?guī)硪黄猨s和jq使用submit方法無法提交表單的快速解決方法。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考
    2016-05-05
  • JavaScript實現(xiàn)彈出DIV層同時頁面背景漸變成半透明效果

    JavaScript實現(xiàn)彈出DIV層同時頁面背景漸變成半透明效果

    這篇文章主要介紹了JavaScript實現(xiàn)彈出DIV層同時頁面背景漸變成半透明效果,涉及JavaScript彈出窗口的實現(xiàn)及頁面元素屬性動態(tài)變換的相關(guān)技巧,需要的朋友可以參考下
    2016-03-03
  • JavaScript獲取頁面中第一個錨定文本的方法

    JavaScript獲取頁面中第一個錨定文本的方法

    這篇文章主要介紹了JavaScript獲取頁面中第一個錨定文本的方法,涉及javascript操作document.archors數(shù)組的技巧,需要的朋友可以參考下
    2015-04-04
  • 使用do...while的方法輸入一個月中所有的周日(實例代碼)

    使用do...while的方法輸入一個月中所有的周日(實例代碼)

    下面小編就為大家?guī)硪黄褂胐o...while的方法輸入一個月中所有的周日(實例代碼)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • JavaScript單一職責原則深入分析

    JavaScript單一職責原則深入分析

    這篇文章主要介紹了理解JavaScript單一職責原則,單一職責原則(SRP:Single?responsibility?principle)又稱單一功能原則,面向?qū)ο笪鍌€基本原則(SOLID)之一,下文更多相關(guān)介紹感興趣的小伙伴可以參考一下
    2022-08-08
  • JS?中在嚴格模式下?this?的指向問題

    JS?中在嚴格模式下?this?的指向問題

    這篇文章主要介紹了JS?中在嚴格模式下this的指向問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09
  • 使用impress.js制作幻燈片

    使用impress.js制作幻燈片

    impress.js是一款新興的幻燈工具,它的效果類似Prezi,但是擁有3D的功能,而且是在MIT&GPL協(xié)議下開源,對于有一定的Web開發(fā)基礎(chǔ)的人而言,真是一個福音,只需要簡單的用些html指令,并加載impress.js就可以制作出一個縮放式幻燈,朋友們感興趣吧,快來一起學習吧。
    2015-09-09
  • js插件dropload上拉下滑加載數(shù)據(jù)實例解析

    js插件dropload上拉下滑加載數(shù)據(jù)實例解析

    這篇文章主要為大家詳細解析了js插件dropload上拉下滑加載數(shù)據(jù)實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-07-07
  • 微信內(nèi)置瀏覽器私有接口WeixinJSBridge介紹

    微信內(nèi)置瀏覽器私有接口WeixinJSBridge介紹

    這篇文章主要介紹了微信內(nèi)置瀏覽器私有接口WeixinJSBridge介紹,本文講解了發(fā)送給好友、分享函數(shù)、隱藏工具欄、隱藏三個點按鈕等功能,需要的朋友可以參考下
    2015-05-05

最新評論