前端将base64图片转换成file文件_base64转file

    type: type
  })
  // 将File文件对象返回给方法的调用者
  return file;

}

// 调用方法 此时的base64是初始file转换的
const file = base64ToFile(base64,‘base64转file生成的文件’)
console.log(‘base64转回file的—’,file);
// 将转换后获得的file文件显示在页面的img元素上
document.querySelector(‘#img’).src = window.webkitURL.createObjectURL(file)


###### 文件转换过程:


![在这里插入图片描述](https://img-blog.csdnimg.cn/fcbd6cbaa71941a3b287246149994ada.png#pic_center)


##### 2、代码解析


​ 该方法涉及知识点较多,首先因为base64的前缀信息部分与文件内容部分是通过`,`进行连接的,`data:image/***;base64(前缀信息),xxxxx(文件内容)`,所以利用`split()`方法对base64进行分割,将前缀文件信息,与文件内容分隔开。得到文件前缀信息后,我们就可以利用`string.match()`方法结合正则表达式,从前缀中获取到文件的类型信息(image/png、image/jpeg、image/webp)以及具体的格式后缀(`png`、`jpeg`、`webp`),保存这些信息,在创建file文件时使用。


​ 接下来我们要对文件内容部分进行处理,借助`window.atob()`方法对base64文件数据进行解码,获取原来的文件数据流信息,但是以字符串的格式输出。然后利用`new Uint8Array(length)`创建一个与文件数据流字符串长度相同的8位无符号的整型数字数组,通过该方法创建的整形数组,所有元素初始值都为0。再通过`while`循环将刚才创建的整形数组中的元素,按照索引替换成文件数据流字串符中对应位置上字符的 UTF-16 代码单元,`string.charCodeAt(index)`可以获取字符串对应index位置字符的 UTF-16 代码单元,值是位于`0~65535`之间的整数数字。


​ 最后我们通过`File(bits, name, options)`构造函数,传入对应的参数创建一个新的file对象后,返回给方法的调用者。至此,完成了base64到file文件的转换。


##### 3、base64


​ 一个完整的base64图片,包含两部分信息的,一部分是文件前缀信息,一部分是表示文件内容信息,例如:`data:image/***(表示文件的类型);base64(表示格式),xxxxx(表示文件内容)`。我们在base64转换为file的过程中,只需要对文件内容信息进行转换即可,但转换后的file文件类型属性,需要通过文件前缀信息来决定。


###### 红线标注部分为文件前缀信息,其余部分为文件内容:


![在这里插入图片描述](https://img-blog.csdnimg.cn/e5f3728a49fa43f1946da04d061d66a6.png#pic_center)


##### 4、`window.atob()`和`window.btoa()`


​ `window.btoa()`方法可以将一个二进制字符串进行编码为base64编码的ASCII 字符串。我们可以使用这个方法对可能遇到通信问题的字符串进行编码处理,但是有一点要注意:该方法不能对中文字符进行编码处理,只能对英文字母、英文符号和数字进行编码处理。


![在这里插入图片描述](https://img-blog.csdnimg.cn/fa2506873abb4b2a8f349ebb1c9484f5.png#pic_center)


​ `window.atob()`方法可以对经过base64编码的字符串进行解码处理,可以将`window.btoa()`编码后的数据,进行还原;也可以将bsae64格式的文件,解码成原本的文件数据流信息。


![在这里插入图片描述](https://img-blog.csdnimg.cn/e33532e8a0a643a69dad9499e67c83da.png#pic_center)


**注:** `window.atob()`和`window.btoa()`兼容IE9以上浏览器。


如果想要实现对中文字符的编码和解码处理,则需要结合`encodeURIComponent()`和`decodeURIComponent()`方法:


**编码的过程:** 中文字符 —> 先encodeURI —> 再btoa编码  
 **解码的过程:** 先atob解码 —> 再decodeURI —> 中文字符


##### 5、File()


​ `File(bits, name[, options])`方法是File对象的构造函数,拥有两个必填参数和一个可选参数:


​ 第一个参数`bits(必填)`,表示文件的内容,可以是包含[`ArrayBuffer`](https://bbs.csdn.net/topics/618166371),[`ArrayBufferView`](https://bbs.csdn.net/topics/618166371),[`Blob`](https://bbs.csdn.net/topics/618166371),或者 [`DOMString`](https://bbs.csdn.net/topics/618166371) 对象的 [`Array`](https://bbs.csdn.net/topics/618166371) ,以及任何这些对象的组合;


​ 第二个参数`name(必填)`,表示创建的file对象的`name`属性,也就是文件的名字。


​ 第三个参数是`options(可选)`,是一个对象格式的参数,表示文件的可选属性,可选属性有两条:① `type`:字符串数据,表示文件的类型(image/png、image/jpeg、image/webp等),默认值为""。 ② `lastModified`:数值型数据,表示文件最后修改时间的Unix时间戳,默认值为`Data.now()`。


##### 6、相关文档


[前端FileReader对象实现图片file文件转base64](https://bbs.csdn.net/topics/618166371)


### 最后:

总结来说,面试成功=基础知识+项目经验+表达技巧+运气。我们无法控制运气,但是我们可以在别的地方花更多时间,每个环节都提前做好准备。

面试一方面是为了找到工作,升职加薪,另一方面也是对于自我能力的考察。能够面试成功不仅仅是来自面试前的临时抱佛脚,更重要的是在平时学习和工作中不断积累和坚持,把每个知识点、每一次项目开发、每次遇到的难点知识,做好积累,实践和总结。

**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/topics/618166371)**

,实践和总结。

**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/topics/618166371)**

![](https://img-blog.csdnimg.cn/img_convert/d63b4ffcebabf2548589be9c3a634aa5.webp?x-oss-process=image/format,png)
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值