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 相关文章推荐
jQuery EasyUI 的EasyLoader功能介绍
Sep 12 Javascript
学习JavaScript的最佳方法分享
Oct 21 Javascript
jQuery :first选择器使用介绍
Aug 09 Javascript
js改变鼠标的形状和样式的方法
Mar 31 Javascript
js判断浏览器版本以及浏览器内核的方法
Jan 20 Javascript
jquery马赛克拼接翻转效果代码分享
Aug 24 Javascript
JavaScript实现多栏目切换效果
Dec 12 Javascript
JS数组排序方法实例分析
Dec 16 Javascript
微信小程序 传值取值的几种方法总结
Jan 16 Javascript
js+css3实现旋转效果
Jan 20 Javascript
js实现unicode码字符串与utf8字节数据互转详解
Mar 21 Javascript
jQuery内容选择器与表单选择器实例分析
Jun 28 jQuery
详解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
第4章 数据处理-php字符串的处理-郑阿奇(续)
2011/07/04 PHP
利用PHP实现短域名互转
2013/07/05 PHP
php读取csv文件后,uft8 bom导致在页面上显示出现问题的解决方法
2013/08/10 PHP
PHP5.3连接Oracle客户端及PDO_OCI模块的安装方法
2016/05/13 PHP
js用Date对象的setDate()函数对日期进行加减操作
2014/09/18 Javascript
js在IE与firefox的差异集锦
2014/11/11 Javascript
JQUERY实现网页右下角固定位置展开关闭特效的方法
2015/07/27 Javascript
jquery实现鼠标点击后展开列表内容的导航栏效果
2015/09/14 Javascript
给angular加上动画效遇到的问题总结
2016/02/17 Javascript
JavaScript数组实现数据结构中的队列与堆栈
2016/05/26 Javascript
javascript 显示全局变量与隐式全局变量的区别
2017/02/09 Javascript
Angular实现购物车计算示例代码
2017/02/21 Javascript
基于vue2的table分页组件实现方法
2017/03/20 Javascript
vue-cli结合Element-ui基于cropper.js封装vue实现图片裁剪组件功能
2018/03/01 Javascript
vue中实现图片和文件上传的示例代码
2018/03/16 Javascript
探秘vue-rx 2.0(推荐)
2018/09/21 Javascript
Vuex的actions属性的具体使用
2019/04/14 Javascript
原生JS无缝滑动轮播图
2019/10/22 Javascript
详解react组件通讯方式(多种)
2020/05/06 Javascript
JS实现手风琴特效
2020/11/08 Javascript
python网络编程学习笔记(五):socket的一些补充
2014/06/09 Python
python实现PID算法及测试的例子
2019/08/08 Python
用Python抢火车票的简单小程序实现解析
2019/08/14 Python
python多进程并发demo实例解析
2019/12/13 Python
Django User 模块之 AbstractUser 扩展详解
2020/03/11 Python
pytorch学习教程之自定义数据集
2020/11/10 Python
Coach澳大利亚官方网站:美国著名时尚奢侈品牌
2017/05/24 全球购物
Myprotein亚太地区:欧洲第一在线运动营养品牌
2020/12/20 全球购物
金智子午JAVA面试题
2015/09/04 面试题
.net工程师笔试题
2012/06/09 面试题
优秀应届毕业生自荐信
2013/11/16 职场文书
大学生职业生涯规划书的基本内容
2014/01/06 职场文书
城市规划应届毕业生自荐信
2014/07/04 职场文书
党的群众路线教育实践活动批评与自我批评范文
2014/10/16 职场文书
公诉意见书范文
2015/06/05 职场文书
基于redis+lua进行限流的方法
2022/07/23 Redis