/** * @description: 图片压缩 * @param {*} src 图片地址 * @param {*} quality 压缩质量 * @param {*} maxWidth 最大宽度 * @param {*} callback 回调函数 * @return {*} */ function compressImage(src, quality, maxWidth, callback) { const img = new Image() img.setAttribute('crossOrigin', 'Anonymous') img.onload = function () { const canvas = document.createElement('canvas') const ctx = canvas.getContext('2d') let width = img.width let height = img.height if (width > maxWidth) { height *= maxWidth / width width = maxWidth } canvas.width = width canvas.height = height ctx.drawImage(img, 0, 0, width, height) const newData = canvas.toDataURL('image/jpeg', quality) // 使用atob()将base64转换为二进制字符串 const binaryString = window.atob(newData.split(',')[1]) const mimeString = newData.split(',')[0].split(':')[1].split(';')[0] // 创建Blob对象 const array = [] for (let i = 0; i < binaryString.length; i++) { array.push(binaryString.charCodeAt(i)) } const blob = new Blob([new Uint8Array(array)], { type: mimeString }) callback(blob) } img.src = src return src } export default function imageCompress(src, quality, maxWidth) { // 使用例子 return compressImage(src, quality, maxWidth, function (blob) { // 创建一个新的图片URL const imageUrl = URL.createObjectURL(blob) // 可以在这里使用imageUrl,比如设置为img元素的src // document.getElementById('your-image-element').src = imageUrl; // 当不需要这个URL的时候,释放它 URL.revokeObjectURL(imageUrl) }) }