Vue+Element-UI实现上传图片并压缩
今天就跟大家聊聊有关Vue+Element-UI实现上传图片并压缩,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

创新互联服务项目包括和硕网站建设、和硕网站制作、和硕网页制作以及和硕网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,和硕网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到和硕省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
template部分
3.script部分
data() {
return {
//压缩质量
imgQuality: 0.5,
imageUrl: ''
}
methods: {
handleAvatarSuccess(res, file) {
// 服务器返回结果处理
},
dataURItoBlob(dataURI, type) {
var binary = atob(dataURI.split(',')[1]);
var array = [];
for(var i = 0; i < binary.length; i++) {
array.push(binary.charCodeAt(i));
}
return new Blob([new Uint8Array(array)], {type: type});
},
beforeAvatarUpload(file) {
const _this = this
return new Promise(resolve => {
const reader = new FileReader()
const image = new Image()
image.onload = (imageEvent) => {
const canvas = document.createElement('canvas');
const context = canvas.getContext('2d');
const width = image.width * _this.imgQuality
const height = image.height * _this.imgQuality
canvas.width = width;
canvas.height = height;
context.clearRect(0, 0, width, height);
context.drawImage(image, 0, 0, width, height);
const dataUrl = canvas.toDataURL(file.type);
const blobData = _this.dataURItoBlob(dataUrl, file.type);
resolve(blobData)
}
reader.onload = (e => { image.src = e.target.result; });
reader.readAsDataURL(file);
})
}
}看完上述内容,你们对Vue+Element-UI实现上传图片并压缩有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。
本文标题:Vue+Element-UI实现上传图片并压缩
当前路径:http://www.jxjierui.cn/article/jjecjs.html


咨询
建站咨询
