网站首页 > 博客文章 正文
在前端开发中,尤其是公众号开发时,手机上传的拍照图片都是非常大,基本都是几兆以上,对于应用存储来说,非常这个图片功能就非常占用磁盘空间,而且在上传下载时,也占用太多的网络资源,
但遇到这种情况时,就需要进入图片等比率进行缩放,把图片压缩至KB级别。以下是前端压缩函数,基本带有注释,供大家参考
调用压缩函数
压缩函数
源码如下:
调用压缩函数
dealImage(this.result, { //压缩 width: 1000 //设置宽为1000,高跟着宽进入缩放 }, function (base) {//压缩返回的文件 api.uploadImgBase64({//调用后台的图片上传接口 'fileName':'img.jpg',//文件上传名 'type':'img',//文件类型 'base64':base//文件传输类型 }).then(res => { ...... }
压缩函数
dealImage(path, obj, callback) {//path图片路径,obj为对象,包含宽和高,callback回调参数 var img = new Image(); img.src = path; img.onload = function(){ var that = this; // 默认按比例压缩 var w = that.width, h = that.height, scale = w / h; w = obj.width || w; h = obj.height || (w / scale); var quality = 0.9; // 默认图片质量为0.5 //生成canvas var canvas = document.createElement('canvas'); var ctx = canvas.getContext('2d'); // 创建属性节点 var anw = document.createAttribute("width"); anw.nodeValue = w; var anh = document.createAttribute("height"); anh.nodeValue = h; canvas.setAttributeNode(anw); canvas.setAttributeNode(anh); ctx.drawImage(that, 0, 0, w, h); // 图像质量 if(obj.quality && obj.quality <= 1 && obj.quality > 0){ quality = obj.quality; } // quality值越小,所绘制出的图像越模糊 var base64 = canvas.toDataURL('image/jpeg', quality ); // 回调函数返回base64的值 callback(base64); } }
猜你喜欢
- 2024-09-17 一文带你搞懂前端登陆设计(前端登录页面模板)
- 2024-09-17 WANGEDITOR 实现CTRL+V粘贴图片并上传、WORD粘贴带图片
- 2024-09-17 前端的鸿蒙开发:照片上传之选择照片mate30 4.2
- 2024-09-17 黑客入门实践:如何绕过前端过滤上传文件
- 2024-09-17 Vue小知识:如何在前端处理上传文件
- 2024-09-17 ueditor粘贴word图片且图片文件自动上传功能
- 2024-09-17 前端上传前预览文件 image、text、json、video、audio「实践」
- 2024-09-17 WANGEDITOR如何能实现直接粘贴把图片上传到服务器中?
- 2024-09-17 前端上传文件或者上传文件夹(前端实现文件上传功能)
- 2024-09-17 前端上传图片被旋转的处理方案(万国觉醒金武将)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)