首页 >> js开发 >> jsvue中实现图片压缩 file文件的方法js大全
jsvue中实现图片压缩 file文件的方法js大全
发布时间: 2021年1月13日 | 浏览:
| 分类:js开发
项目中遇到上传图片需要在前端进行图片压缩,将我的实现思路记录一下。(我已经拿到上传的file文件的前提下)项目中遇到上传图片需要在前端进行图片压缩,将我的实现思路记录一下。(我已经拿到上传的file文件的前提下)先创建一个公用的js,这里我的是api.js,里面封装一些常用的方法将图片压缩的方法写到这个公用的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,
}
//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
//注册为全局变量
import api from './http/api.js' //这里注意自己的路径
Vue.prototype.$api = api
//注册为全局变量接下来在需要的地方调用我们的公用方法
this.$api.compressImg()//调用
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
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)
}
}
//上传前压缩图片
async beforeRead(file){//async await 解决异步问题,
var formData = new FormData();//创建新的form
if(file.length){
//file.length为真的时候说明是多图上传
要循环多图将file对象放进form中
for(let i=0;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了!总结总结总结
//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,
}
//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
//注册为全局变量
import api from './http/api.js' //这里注意自己的路径
Vue.prototype.$api = api
//注册为全局变量接下来在需要的地方调用我们的公用方法
this.$api.compressImg()//调用
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
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)
}
}
//上传前压缩图片
async beforeRead(file){//async await 解决异步问题,
var formData = new FormData();//创建新的form
if(file.length){
//file.length为真的时候说明是多图上传
要循环多图将file对象放进form中
for(let i=0;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了!总结总结总结
相关文章:
- jsVue-CLI 3 scp2自动部署项目至服务器的方法js大全
- js谈一谈vue请求数据放在created好还是mounted里好js大全
- js解决vue的router组件component在import时不能使用变量问题js大全
- js在vue中使用防抖函数组件操作js大全
- jsVue中的this.$options.data()和this.$data用法说明js大全
- jsElement Breadcrumb 面包屑的使用方法js大全
- js解决vue动态路由异步加载import组件,加载不到module的问题js大全
- jsAngular利用HTTP POST下载流文件的步骤记录js大全
- js解决vuex数据页面刷新后初始化操作js大全
- jsvue 页面回退mounted函数不执行的解决方案js大全