前端base64与图片相互转换(附代码)
更新时间:2023年09月13日 09:43:27 作者:MoXinXueWEB
有时候会遇到要把前端发送过来的图片的文件base64编码转化成图片,所以下面这篇文章主要给大家介绍了关于前端base64与图片相互转换的相关资料,需要的朋友可以参考下
base64转图片
如下图:(后端返回的数据)
<img :src="baseImg" > let baseImg = "" this.baseImg ="data:image/png;base64," + data?.flowChar
base64转换图片文件
base64ImgtoFile = (dataurl, filename = 'file') => { let arr = dataurl.split(',') let mime = arr[0].match(/:(.*?);/)[1] let suffix = mime.split('/')[1] let bstr = atob(arr[1]) let n = bstr.length let u8arr = new Uint8Array(n) while (n--) { u8arr[n] = bstr.charCodeAt(n) } return new File([u8arr], `${filename}.${suffix}`, { type: mime }) }, // base64编码的图片 baseImg = ''; //转换图片文件 const imgFile = base64ImgtoFile(baseImg); console.log("imgFile",imgFile);
图片(url)转换base64
getBase64 = (url, callback) => { let Img = new Image(), dataURL = ''; Img.src = url + '?v=' + Math.random(); Img.setAttribute('crossOrigin', 'Anonymous'); Img.onload = function() { let canvas = document.createElement('canvas'), width = Img.width, height = Img.height; canvas.width = width; canvas.height = height; canvas.getContext('2d').drawImage(Img, 0, 0, width, height); dataURL = canvas.toDataURL('image/jpeg', 1); //可选取多种模式 return callback ? callback(dataURL) : null; //回掉函数获取Base64编码 }; } // 调用 let imgUrl=‘https://www.baidu.com/img/bd_logo1.png' this.getBase64(imgUrl, dataURL => { console.log(dataURL:就是base64了) });
便捷的图片转化base64
利用 Chrome 浏览器,在 chrome 下新建一个窗口,然后把要转化的图片直接拖入浏览器,打开控制台,点 Source,如下图所示,点击图片,右侧就会显示该图片的 base64 编码
总结
到此这篇关于前端base64与图片相互转换的文章就介绍到这了,更多相关base64与图片相互转换内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
最新评论