vue中的base64图片转网络URL方式
作者:Juliet_xmj
在Vue中,可以直接将Base64编码的图片赋值给img元素的src属性,此外,也可以通过JavaScript的URL.createObjectURL()方法将Base64转换为Blob URL,进而转换为File对象,并可进一步转换为PNG或其他格式的图片,这种转换技术在前端开发中非常实用
vue base64图片转网络URL
src支持base64图片,正常base64图片可以直接复制到图片src,也可以将其转为URL
// data url: 'XXXXXXXX' // base64编码 imgUrl: '' // 图片路径 // methods base64ImgtoFile (dataurl, filename = 'file') { const arr = dataurl.split(',') const mime = arr[0].match(/:(.*?);/)[1] const suffix = mime.split('/')[1] const bstr = atob(arr[1]) let n = bstr.length const u8arr = new Uint8Array(n) while (n--) { u8arr[n] = bstr.charCodeAt(n) } return new File([u8arr], `${filename}.${suffix}`, { type: mime }) },
打印得到File文件,再转为png图片
const img = 'data:image/png;base64,' + img this.file = this.base64ImgtoFile(img) // 得到File对象 this.imgUrl = window.webkitURL.createObjectURL(file) || window.URL.createObjectURL(file) // imgUrl图片网络路径
base64转url、url转base64
// url转base64 dataURLtoBlob(dataurl) { return new Promise((resolve, reject) => { let 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); } resolve(new Blob([u8arr], {type:mime})); }) }, const images = await Promise.all([ this.dataURLtoBlob(this.imageUrl), this.dataURLtoBlob(this.imageUrl2), ]) // base64转url dataURLtoBlobURL(dataUrl) { return new Promise((resolve, reject) => { let 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); } let blob = new Blob([u8arr], {type:mime}); let url = URL.createObjectURL(blob); resolve(url); }); }, let url1 = await this.dataURLtoBlobURL(this.imageUrl); let url2 = await this.dataURLtoBlobURL(this.imageUrl2);
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。