image, blob, File, base64互相转换方法

复制代码
//将image url、blob url等转化为blob对象
async function urlToBlob (url) {
  return new Promise((resolve,reject) => {
    var xhr = new XMLHttpRequest();
    xhr.open('get', url, true);
    xhr.responseType = 'blob';
    xhr.onload = function () {
      if(this.status == 200 || this.status === 0){
        // 注意这里的this.response 是一个blob对象 就是文件对象
        resolve(this.response)
      }
      else{
        reject(null)
      }
    }
    xhr.send();
  })
}

//将base64转换为blob
function base64toBlob(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
function blobToFile(theBlob, fileName){
  theBlob.lastModifiedDate = new Date();
  theBlob.name = fileName;
  return theBlob;
}

//file转base64
async function fileToBase64(file){
  return new Promise((resolve,reject) => {
    let reader=new FileReader();
    reader.readAsDataURL(file);
    reader.onload=function(e){
      resolve(this.result);
    }
    reader.error=function(){
      reject(this.error);
    }
  })
}

//image转base64
function imgToBase64(img,mime="image/png"){
  let canvas = document.createElement("canvas");
  canvas.width = img.width;
  canvas.height = img.height;
  let ctx = canvas.getContext("2d");
  img.crossOrigin= 'anonymous';
  ctx.drawImage(img, 0, 0, img.width, img.height);
  delete img.crossOrigin;
  let dataURL = canvas.toDataURL(mime);
  return dataURL
}
复制代码

 

posted @   全玉  阅读(1940)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示