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 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 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工具