vue中实现图片压缩 file文件的方法


Posted in Javascript onMay 28, 2020

项目中遇到上传图片需要在前端进行图片压缩,将我的实现思路记录一下。(我已经拿到上传的file文件的前提下)

先创建一个公用的js,这里我的是api.js,里面封装一些常用的方法

vue中实现图片压缩 file文件的方法

将图片压缩的方法写到这个公用的js(api.js)中

//base64转码(压缩完成后的图片为base64编码,这个方法可以将base64编码转回file文件)
function dataURLtoFile(dataurl) {
  var arr = dataurl.split(','),
    mime = arr[0].match(/:(.*?);/)[1],
    bstr = atob(arr[1]),
    n = bstr.length,
    u8arr = new Uint8Array(n);
  while (n--) {
    u8arr[n] = bstr.charCodeAt(n);
  }
  return new File([u8arr], { type: mime });

}
//压缩图片
function compressImg(file){
  var src;
  var files;
  var fileSize = parseFloat(parseInt(file['size'])/1024/1024).toFixed(2);
  var read = new FileReader();
  read.readAsDataURL(file);
  return new Promise(function(resolve, reject){
   read.onload = function (e) {
     var img = new Image();
     img.src = e.target.result;
     img.onload = function(){
       //默认按比例压缩
       var w = this.width,
         h = this.height;
       //生成canvas
       var canvas = document.createElement('canvas');
       var ctx = canvas.getContext('2d');
       var base64;
       // 创建属性节点
       canvas.setAttribute("width", w);
       canvas.setAttribute("height", h);
       ctx.drawImage(this, 0, 0, w, h);
       if(fileSize<1){
         //如果图片小于一兆 那么不执行压缩操作
         base64 = canvas.toDataURL(file['type'], 1);
       }else if(fileSize>1&&fileSize<2){
         //如果图片大于1M并且小于2M 那么压缩0.5
         base64 = canvas.toDataURL(file['type'], 0.5);
       }else{
         //如果图片超过2m 那么压缩0.2
         base64 = canvas.toDataURL(file['type'], 0.2);
       }
       // 回调函数返回file的值(将base64编码转成file)
       files = dataURLtoFile(base64); //如果后台接收类型为base64的话这一步可以省略
       
       resolve(files)
     };
   };
  })
};

//结尾处将该方法暴露出来供外部调用
export default {	
 compressImg,
}

在main.js中引入公用js(api.js)

import api from './http/api.js' //这里注意自己的路径
Vue.prototype.$api = api  //注册为全局变量

接下来在需要的地方调用我们的公用方法

this.$api.compressImg()//调用

我的调用方法
图片压缩的方法为异步执行 使用async await 解决异步问题(需要等压缩完成后)

//上传前压缩图片
   async beforeRead(file){//async await 解决异步问题,
    var formData = new FormData();//创建新的form
    if(file.length){   //file.length为真的时候说明是多图上传  要循环多图将file对象放进form中
     for(let i=0;i<file.length;i++){
      var f = await this.$api.compressImg(file[i]) //await只能放在async函数里 await会等待异步方法的返回值拿到以后在执行后面的方法
     formData.set('file'+i,f)
     }
    }else{
     let f = await this.$api.compressImg(file)
     formData.set('file0',f)
    }
   }

然后将formData传给后台,生成图片的线上地址就OK了!

总结

到此这篇关于vue中实现图片压缩 file文件的方法的文章就介绍到这了,更多相关vue图片压缩内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
繁简字转换功能
Jul 19 Javascript
javascript 读取xml,写入xml 实现代码
Jul 10 Javascript
键盘上一张下一张兼容IE/google/firefox等浏览器
Jan 28 Javascript
jQuery实现的AJAX简单弹出层效果代码
Nov 26 Javascript
使用vue.js制作分页组件
Jun 27 Javascript
jQuery的Read()方法代替原生JS详解
Nov 08 Javascript
JS完成画圆圈的小球
Mar 07 Javascript
es6系列教程_ Map详解以及常用api介绍
Sep 25 Javascript
vue组件详解之使用slot分发内容
Apr 09 Javascript
jQuery实现动画、消失、显现、渐出、渐入效果示例
Sep 06 jQuery
微信小程序实现基于三元运算验证手机号/姓名功能示例
Jan 19 Javascript
JS实现电商商品展示放大镜特效
Jan 07 Javascript
详解Vue 数据更新了但页面没有更新的 7 种情况汇总及延伸总结
May 28 #Javascript
Vue实现附件上传功能
May 28 #Javascript
如何使用Javascript中的this关键字
May 28 #Javascript
简单了解JavaScript arguement原理及作用
May 28 #Javascript
如何使用JavaScript检测空闲的浏览器选项卡
May 28 #Javascript
js实现轮播图特效
May 28 #Javascript
JS写滑稽笑脸运动效果
May 28 #Javascript
You might like
关于拼配咖啡,你要知道
2021/03/03 咖啡文化
php环境配置 php5 MySQL5 apache2 phpmyadmin安装与配置图文教程
2007/03/16 PHP
php 正确解码javascript中通过escape编码后的字符
2010/01/28 PHP
支持数组的ADDSLASHES的php函数
2010/02/16 PHP
PHP 开发环境配置(测试开发环境)
2010/04/28 PHP
php对数组排序代码分享
2014/02/24 PHP
使用PHPMailer实现邮件发送代码分享
2014/10/23 PHP
php绘制一个矩形的方法
2015/01/24 PHP
php+mysqli实现批量执行插入、更新及删除数据的方法
2015/01/29 PHP
php中文验证码实现方法
2015/06/18 PHP
PHP与以太坊交互详解
2018/08/24 PHP
PHP图像处理 imagestring添加图片水印与文字水印操作示例
2020/02/06 PHP
文本框倒叙输入让输入框的焦点始终在最开始的位置
2014/09/01 Javascript
JS截取字符串实例详解
2015/11/24 Javascript
高效利用Angular中内置服务$http、$location等
2016/03/22 Javascript
全选复选框JavaScript编写小结(附代码)
2017/08/16 Javascript
深入理解Vue.js轻量高效的前端组件化方案
2018/12/10 Javascript
JS实现图片轮播效果实例详解【可自动和手动】
2019/04/04 Javascript
layui下拉框获取下拉值(select)的例子
2019/09/10 Javascript
前端使用crypto.js进行加密的函数代码
2020/08/16 Javascript
[49:31]TFT vs Mski Supermajor小组赛C组 BO3 第一场 6.3
2018/06/04 DOTA
基于python批量处理dat文件及科学计算方法详解
2018/05/08 Python
使用PyInstaller将python转成可执行文件exe笔记
2018/05/26 Python
基于scrapy的redis安装和配置方法
2018/06/13 Python
解决Python下json.loads()中文字符出错的问题
2018/12/19 Python
超简单使用Python换脸实例
2019/03/27 Python
python 使用plt画图,去除图片四周的白边方法
2019/07/09 Python
python matplotlib包图像配色方案分享
2020/03/14 Python
django 解决扩展自带User表遇到的问题
2020/05/14 Python
python 使用xlsxwriter循环向excel中插入数据和图片的操作
2021/01/01 Python
css3中的calc函数浅析
2018/07/10 HTML / CSS
装饰活动策划方案
2014/02/11 职场文书
党的群众路线教育实践活动个人对照检查材料(乡镇)
2014/11/05 职场文书
2015年个人现实表现材料
2014/12/10 职场文书
年度考核表个人总结
2015/03/06 职场文书
详细分析PHP7与PHP5区别
2021/06/26 PHP