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 option删除代码集合
Nov 12 Javascript
jquery实现简单的拖拽效果实例兼容所有主流浏览器
Jun 21 Javascript
js+css 实现遮罩居中弹出层(随浏览器窗口滚动条滚动)
Dec 11 Javascript
JS实现两表格里数据来回转移的方法
May 28 Javascript
jQuery validate插件submitHandler提交导致死循环解决方法
Jan 21 Javascript
vue中如何引入jQuery和Bootstrap
Apr 10 jQuery
js canvas实现适用于移动端的百分比仪表盘dashboard
Jul 18 Javascript
详解javascript中的变量提升和函数提升
May 24 Javascript
Vue中在新窗口打开页面及Vue-router的使用
Jun 13 Javascript
jQuery高级编程之js对象、json与ajax用法实例分析
Nov 01 jQuery
JS实现鼠标按下拖拽效果
Jul 23 Javascript
原生JS实现音乐播放器的示例代码
Feb 25 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
星际争霸 Starcraft 秘技补丁
2020/03/14 星际争霸
JS随即打乱数组实现代码
2012/12/03 Javascript
js获取光标位置和设置文本框光标位置示例代码
2014/01/09 Javascript
js 数值转换为3位逗号分隔的示例代码
2014/02/19 Javascript
flash遮住div问题的正确解决方法
2014/02/27 Javascript
页面加载完后自动执行一个方法的js代码
2014/09/06 Javascript
JavaScript中的getDay()方法使用详解
2015/06/09 Javascript
详解JavaScript正则表达式之RegExp对象
2015/12/13 Javascript
JQuery ztree带筛选、异步加载实例讲解
2016/02/25 Javascript
微信小程序 实战程序简易新闻的制作
2017/01/09 Javascript
vue.js获取数据库数据实例代码
2017/05/26 Javascript
vue项目部署到Apache服务器中遇到的问题解决
2018/08/24 Javascript
详解微信小程序框架wepy踩坑记录(与vue对比)
2019/03/12 Javascript
vue中使用vue-print.js实现多页打印
2020/03/05 Javascript
js简单实现自动生成表格功能示例
2020/06/02 Javascript
vue 重塑数组之修改数组指定index的值操作
2020/08/09 Javascript
基于javascript实现放大镜特效
2020/12/03 Javascript
了不起的11个JavaScript代码重构最佳实践小结
2021/01/11 Javascript
python实现2014火车票查询代码分享
2014/01/10 Python
Python求两个list的差集、交集与并集的方法
2014/11/01 Python
Python连接PostgreSQL数据库的方法
2016/11/28 Python
python实现随机森林random forest的原理及方法
2017/12/21 Python
python分治法求二维数组局部峰值方法
2018/04/03 Python
pandas把dataframe转成Series,改变列中值的类型方法
2018/04/10 Python
numpy.where() 用法详解
2019/05/27 Python
Pandas 缺失数据处理的实现
2019/11/04 Python
matplotlib自定义鼠标光标坐标格式的实现
2021/01/08 Python
有关HTML5 Video对象的ontimeupdate事件(Chrome上无效)的问题
2013/07/19 HTML / CSS
Canvas高级路径操作之拖拽对象的实现
2019/08/05 HTML / CSS
园林技术专业求职信
2014/07/28 职场文书
社区精神文明建设汇报材料
2014/08/17 职场文书
领导干部对照检查材料
2014/08/24 职场文书
电力工程合作意向书
2015/05/11 职场文书
工商行政处罚决定书
2015/06/24 职场文书
整脏治乱工作简报
2015/07/21 职场文书
职场新人刚入职工作总结该怎么写?
2019/05/15 职场文书