vue压缩base64图片方法 【Javascript】
//压缩方法 dealImage(base64, w, callback) { var newImage = new Image(); var quality = 0.6; //压缩系数0-1之间 newImage.src = base64; newImage.setAttribute( "crossOrigin" , 'Anonymous' ); //url为外域时需要 var imgWidth, imgHeight; newImage.onload = function () { imgWidth = 160; imgHeight = 90; var canvas = document.createElement( "canvas" ); var ctx = canvas.getContext( "2d" ); if (Math.max(imgWidth, imgHeight) > w) { if (imgWidth > imgHeight) { canvas.width = w; canvas.height = w * imgHeight / imgWidth; } else { canvas.height = w; canvas.width = w * imgWidth / imgHeight; } } else { canvas.width = imgWidth; canvas.height = imgHeight; quality = 0.6; } ctx.clearRect(0, 0, canvas.width, canvas.height); ctx.drawImage( this , 0, 0, canvas.width, canvas.height); var base64 = canvas.toDataURL( "image/jpeg" , quality); //压缩语句 // 如想确保图片压缩到自己想要的尺寸,如要求在50-150kb之间,请加以下语句,quality初始值根据情况自定 // while (base64.length / 1024 > 150) { // quality -= 0.01; // base64 = canvas.toDataURL("image/jpeg", quality); // } // 防止最后一次压缩低于最低尺寸,只要quality递减合理,无需考虑 // while (base64.length / 1024 < 50) { // quality += 0.001; // base64 = canvas.toDataURL("image/jpeg", quality); // } callback(base64); //必须通过回调函数返回,否则无法及时拿到该值,return拿不到 } } |
1 2 3 4 5 6 7 8 | // 调用方法 let base64 = res.data; //传入base64变量 console.log(base64.length, '11' ,base64); // 打印原长度 vm.dealImage(base64, 150, useImg); function useImg(data){ vm.formValidate.img = data console.log(vm.formValidate.img.length, '22' ,vm.formValidate.img); // 打印压缩长度 } |
本文来自博客园,作者:小珍珠在河里敲代码,转载请注明原文链接:https://www.cnblogs.com/Jansens520/p/16813554.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)