JS将图片转Base64的两种方法

山楂树の 2024-06-17 17:05:05 阅读 56

第一种:Blob和FileReader 对象

实现原理:

使用xhr请求图片,并设置返回的文件类型为Blob对象[xhr.responseType = “blob”]

使用FileReader 对象接收blob

return new Promise(resolve => { let xhr = new XMLHttpRequest() xhr.open('get', src, true) xhr.responseType = 'blob' xhr.onload = function () { if (this.status == 200) { let blob = this.response let oFileReader = new FileReader() oFileReader.onloadend = function (e) { const base64 = e.target.result resolve(base64) } oFileReader.readAsDataURL(blob) } } xhr.send() })

第二种:canvas.toDataURL()

实现原理:

使用canvas.toDataURL()方法

需要解决图片跨域问题 image.crossOrigin = ‘’;

return new Promise(resolve => { const img = new Image() img.crossOrigin = '' img.src = src img.onload = function () { const canvas = document.createElement('canvas') canvas.width = img.width canvas.height = img.height const ctx = canvas.getContext('2d') ctx?.drawImage(img, 0, 0, img.width, img.height) const ext = img.src.substring(img.src.lastIndexOf('.') + 1).toLowerCase() const dataURL = canvas.toDataURL('image/' + ext) resolve(dataURL) }



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。