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 相关文章推荐
js右键菜单效果代码
Jul 21 Javascript
让getElementsByName适应IE和firefox的方法
Sep 24 Javascript
JSON 编辑器实现代码
Dec 06 Javascript
js如何获取object类型里的键值
Feb 18 Javascript
实例说明为什么不要行内使用javascript
Apr 18 Javascript
简单谈谈node.js 版本控制 nvm和 n
Oct 15 Javascript
Vue.js学习笔记之常用模板语法详解
Jul 25 Javascript
Angular通过angular-cli来搭建web前端项目的方法
Jul 27 Javascript
jQuery中each循环的跳出和结束实例
Aug 16 jQuery
JavaScript实现正则去除a标签并保留内容的方法【测试可用】
Jul 18 Javascript
微信小程序常用赋值方法小结
Apr 30 Javascript
vue前后分离调起微信支付
Jul 29 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
PHP限制页面只能在微信自带浏览器访问的代码
2014/01/15 PHP
PHP实现linux命令tail -f
2016/02/22 PHP
Symfony的安装和配置方法
2016/03/17 PHP
浅谈PHP表单提交(POST&amp;GET&amp;URL编/解码)
2017/04/03 PHP
PHP 无限级分类
2017/05/04 PHP
Javascript的IE和Firefox兼容性汇编
2006/07/01 Javascript
Grid得到选择行数据的方法总结
2011/01/17 Javascript
JsRender for index循环索引用法详解
2014/10/31 Javascript
JS函数this的用法实例分析
2015/02/05 Javascript
解决bootstrap中modal遇到Esc键无法关闭页面
2015/03/09 Javascript
jquery图片切换插件
2015/03/16 Javascript
jfreechart插件将数据展示成饼状图、柱状图和折线图
2015/04/13 Javascript
JavaScript使用cookie实现记住账号密码功能
2015/04/27 Javascript
JS实现两表格里数据来回转移的方法
2015/05/28 Javascript
封装获取dom元素的简单实例
2016/07/08 Javascript
js实现PC端和移动端刮卡效果
2020/03/27 Javascript
JQuery EasyUI的一些常用组件
2017/07/12 jQuery
详解写好JS条件语句的5条守则
2019/02/28 Javascript
解决layUI的页面显示不全的问题
2019/09/20 Javascript
微信小程序wxs实现吸顶效果
2020/01/08 Javascript
[00:36]DOTA2勇士令状莱恩声望物品——冥晶之厄展示
2018/05/25 DOTA
Python中实现字符串类型与字典类型相互转换的方法
2014/08/18 Python
用Pygal绘制直方图代码示例
2017/12/07 Python
Python PyAutoGUI模块控制鼠标和键盘实现自动化任务详解
2018/09/04 Python
Django之Mode的外键自关联和引用未定义的Model方法
2018/12/15 Python
python 获取毫秒数,计算调用时长的方法
2019/02/20 Python
python中property属性的介绍及其应用详解
2019/08/29 Python
keras topN显示,自编写代码案例
2020/07/03 Python
CSS3+Sprite实现僵尸行走动画特效源码
2016/01/27 HTML / CSS
HTML5实现视频直播功能思路详解
2017/11/16 HTML / CSS
美国祛痘、抗衰老药妆品牌:Murad
2016/08/27 全球购物
美术国培研修感言
2014/02/12 职场文书
大学活动总结格式
2014/04/29 职场文书
水电站项目建议书
2014/05/12 职场文书
求职信结尾怎么写
2014/05/26 职场文书
小学运动会前导词
2015/07/20 职场文书