file文件对象转base64-base64转file文件对象

本文详细介绍了如何将文件对象转换为Base64编码,并提供了将Base64编码还原为文件对象的方法。通过JavaScript实现,适用于前端项目中图片的预览和上传场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

file文件对象转base64

file文件对象的格式:
在这里插入图片描述

fileToBase64(file){
            let that =this,
            reader = new FileReader();
            reader.readAsDataURL(file);
            return new Promise((resolve,reject)=>{
                reader.onload = function (e) { //这里是一个异步,所以获取数据不好获取在实际项目中,就用new Promise解决
                    if(this.result){
                        resolve(this.result)
                    }else{
                        reject("err")
                    }

                }
            })  
        }
     //----------------------------------------------------
     调用
     this.fileToBase64(imgFile).then(res=>{
            console.log("这里的res就是base64文件",res)
            })

!!!file文件对象的照片不可以直接在img标签中使用

base64转file文件对象

base64的文件格式就是一大串编码
!!!base64的文件格式是可以直接在img标签中使用的

base64TOfile(base64){
      let that = this;
      var arr = base64.split(',');
      var mime = arr[0].match(/:(.*?);/)[1];
      var bstr = atob(arr[1]); // 解码base-64编码的数据
      var n = bstr.length; 
      var u8arr = new Uint8Array(n);// 无符号整型数组
      while(n--){
          u8arr[n] = bstr.charCodeAt(n);
      }
      //转换成file对象
      let filename = new Date().getTime();
      let filetest = new File([u8arr], filename, {type:mime})
      return filetest
    }
    //-------------------------------------------------调用
    this.base64TOfile(this.takeImgsbase64[index].file[1])
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值