0


js实现base64,url,blob之间的相互转换

一般来说前端展示图片会通过三种方式: url、base64、blob

1.url: 一般来说,图片的显示还是建议使用url的方式比较好。

let url ="http://xxxxxx"

2.base64: 如果图片较大,图片的色彩层次比较丰富,则不适合使用这种方式,因为其Base64编码后的字符串非常大,会明显增大HTML页面,影响加载速度。如果图片像loading或者小图标,小图片这样的,大小极小,但又占据了一次HTTP请求,而很多地方都会使用。则非常适用“base64:URL图片”技术进行优化了!

let base64Str =".....AAAAElFTkSuQmCC"

3.blob: 当后端返回特定的图片二进制流的时候,前端用blob容器接收二进制流,再通过

URL.createObjectURL(blob)生成一个临时blob展示地址

关系图
在这里插入图片描述

url 转 base64

原理: 利用

canvas.toDataURL

的API转化成

base64
functionurlToBase64(url){returnnewPromise((resolve,reject)=>{let image =newImage();
        image.onload =function(){let canvas = document.createElement('canvas');
          canvas.width =this.naturalWidth;
          canvas.height =this.naturalHeight;// 将图片插入画布并开始绘制
          canvas.getContext('2d').drawImage(image,0,0);// resultlet result = canvas.toDataURL('image/png')resolve(result);};// CORS 策略,会存在跨域问题https://stackoverflow.com/questions/20424279/canvas-todataurl-securityerror
        image.setAttribute("crossOrigin",'Anonymous');
        image.src = url;// 图片加载失败的错误处理
        image.onerror =()=>{reject(newError('urlToBase64 error'));};}

使用

let imgUrL = `http://XXX.jpg`
urlToBase64(imgUrL).then(res =>{// 转化后的base64图片地址
  console.log('base64', res)})

blob 转 url

原理: 利用

URL.createObjectURL

为blob对象创建临时的

URL
var url = URL.createObjectURL(blob)

blob 转 base64

原理: 利用

fileReader

readAsDataURL

,将

blob

转为

base64
blobToBase64(blob){returnnewPromise((resolve, reject)=>{const fileReader =newFileReader();
    fileReader.onload =(e)=>{resolve(e.target.result);};// readAsDataURL
    fileReader.readAsDataURL(blob);
    fileReader.onerror =()=>{reject(newError('blobToBase64 error'));};});}

使用

blobToBase64(blob).then(res =>{// 转化后的base64
  console.log('base64', res)})

base64 转 Blob

原理:

Uint8Array

ArrayBuffer

构造

functionbase64toBlob(dataurl){var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
        bstr =atob(arr[1]), n = bstr.length, u8arr =newUint8Array(n);while(n--){
        u8arr[n]= bstr.charCodeAt(n);}returnnewBlob([u8arr],{ type: mime });}

或者

function baseToBlob (b64){const byteCharacters =atob(b64)const byteNumbers =newArray(byteCharacters.length)for(let i =0; i < byteCharacters.length; i++){
        byteNumbers[i]= byteCharacters.charCodeAt(i)}const byteArray =newUint8Array(byteNumbers)const blob =newBlob([byteArray],{ type: 'image/jpeg' })return blob
    }//需要你手动去掉data:image/png;base64,

使用:

let base64Str =".....AAANSUhEUgAA"dataURLtoBlob(base64Str)

或者,利用

fetch(推荐)
fetch(`data:${type};base64,${base64}`).then(res => res.blob())

字符串 和 base64 之间互转

原理:

atob

btoa
let str =btoa("Dsgsg1234567890-=[];'m,,./")
console.log(str)//RHNnc2cxMjM0NTY3ODkwLT1bXTsnbSwsLi8=
console.log(atob(str))//Dsgsg1234567890-=[];'m,,./

而且大部分浏览器都支持 除了 IE9-btoa 方法

不支持中文和特殊字符,否则会报错

所以保险起见,在转换之前还是

encodeURIComponent/encodeURI

一下吧, 当然别忘了在

atob

后,再

decodeURIComponent/decodeURI

回来。

标签: javascript 前端

本文转载自: https://blog.csdn.net/weixin_48567214/article/details/128574399
版权归原作者 冬天不会冷lz 所有, 如有侵权,请联系我们删除。

“js实现base64,url,blob之间的相互转换”的评论:

还没有评论