直接上代码
<el-upload
:before-upload="onBeforeUpload"
>
js
onBeforeUpload(file) {
const isJPG =
file.type === "image/jpeg" ||
file.type === "image/gif" ||
file.type === "image/jpg" ||
file.type === "image/png" ||
file.type === "image/GIF" ||
file.type === "image/JPG" ||
file.type === "image/bmp";
if (!isJPG) {
this.$message.error("图片格式不正确!");
return false;
}
return new Promise((resolve, reject) => {
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = (e) => {
const img = new Image();
img.src = e.target.result;
img.onload = () => {
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
canvas.width = 110; // 设置压缩后图片的宽度
canvas.height = 110; // 根据原始图片比例计算压缩后图片的高度
ctx.drawImage(img, 0, 0, canvas.width, canvas.height);
canvas.toBlob((blob) => {
const compressedFile = new File([blob], file.name, { type: file.type, lastModified: Date.now() });
resolve(compressedFile);
}, file.type);
};
};
});
},