2025年3月19日 星期三 甲辰(龙)年 月十八 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 编程开发 > JavaScript

js 把base64转file文件的两种方式

时间:05-29来源:作者:点击数:35

最近项目中需要实现把图片的base64编码转成file文件的功能,然后再上传至服务器。起初是直接通过new File()的方式进行转换,在各个主流的浏览器基本上都支持,Android也没问题,但是在ios系统埋了个坑,ios11.4以下的系统上传失败。定位bug发现是new File()这个方法不兼容ios系统,只能另辟蹊径,最后找到一个方法就是:

将base64转成blob ——> blob转成file

这种方式测试通过,解决了new File()不兼容ios系统问题。下面将base64转file文件两种方式的代码贴出来:

1.通过new File()将base64转换成file文件,此方式需考虑浏览器兼容问题。

  • //将base64转换为文件
  • 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 });
  • },
  • //调用
  • var file = dataURLtoFile(base64Data, imgName);

2.先将base64转换成blob,再将blob转换成file文件,此方法不存在浏览器不兼容问题。

  • //将base64转换为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转换为file
  • blobToFile: function(theBlob, fileName){
  • theBlob.lastModifiedDate = new Date();
  • theBlob.name = fileName;
  • return theBlob;
  • },
  • //调用
  • var blob = dataURLtoBlob(base64Data);
  • var file = blobToFile(blob, imgName);
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门