vue2+elementui使用compressorjs压缩上传的图片

首先是npm install compressorjs

然后新建一个compressorjs.js的文件

复制代码
import Compressor from "compressorjs";

// 默认压缩配置
const DEFAULT_COMPRESS_OPTIONS = {
  quality: 0.6, // 默认压缩质量 (0-1)
  maxWidth: 1920, // 最大宽度
  maxHeight: 1080, // 最大高度
  convertSize: 5 * 1024 * 1024, // 超过5MB的图片转为WebP
};

/**
 * 压缩图片文件
 * @param {File} file - 待压缩的图片文件
 * @param {Object} options - 压缩配置项
 * @returns {Promise<File>} 压缩后的文件
 */
export function compressImage(file, options = {}) {
  return new Promise((resolve, reject) => {
    // 合并配置并限制最小压缩质量
    const mergedOptions = {
      ...DEFAULT_COMPRESS_OPTIONS,
      ...options,
      quality: Math.max(
        0.1,
        options.quality ?? DEFAULT_COMPRESS_OPTIONS.quality
      ),
      maxWidth: Math.min(
        options.maxWidth ?? DEFAULT_COMPRESS_OPTIONS.maxWidth,
        8192
      ),
      maxHeight: Math.min(
        options.maxHeight ?? DEFAULT_COMPRESS_OPTIONS.maxHeight,
        8192
      ),
    };

    // 执行压缩
    new Compressor(file, {
      ...mergedOptions,
      success(result) {
        if (!result) {
          return reject(new Error("Compression result is empty"));
        }
        resolve(new File([result], file.name, { type: result.type }));
      },
      error(err) {
        reject(err);
      },
    });
  });
}

具体的使用页面。只用在上传之前before-upload的函数中压缩就可以啦

复制代码
<el-upload
  :before-upload="beforeUploadImg"
>
</el-upload>
复制代码
import { compressImage } from "@/utils/imageCompress";

async beforeUploadImg(file) {
  const fileSize = file.size / 1024 / 1024;
  let types = ["image/jpeg", "image/jpg", "image/png", "application/pdf"];
  const isImageOrPDF = types.includes(file.type);
  if (!isImageOrPDF) {
    this.$message.error("上传图片只能是 JPG/JPEG/PNG/PDF 格式!");
    return false;
  }

  try {
    // 压缩图片(仅处理大于5MB的图片)。当前你也可以不加这个限制就是压缩所有上传的图片
    if (fileSize > 5) {
      const compressedFile = await compressImage(file, {
        quality: fileSize > 10 ? 0.7 : 1,
        axWidth: Infinity, // 不限制宽度
        maxHeight: Infinity, // 不限制高度
      });
      return compressedFile; // 返回压缩后的文件
    }
    return file;
  } catch (err) {
    if (fileSize > 5) {
      this.$message({
        message: "上传图片大小超过限制",
        type: "warning",
      });
      return false;
    }
    console.error("压缩失败:", err);
    return file; // 降级处理:上传原文件
  }

}

相关推荐
颜酱9 分钟前
二叉树分解问题思路解题模式
javascript·后端·算法
晨米酱9 分钟前
四、Prettier 编辑器集成指南
前端·代码规范
文心快码BaiduComate14 分钟前
Comate 4.0新年全面焕新!底层重构、七大升级、复杂任务驾驭力跃升
前端·程序员·架构
怪可爱的地球人24 分钟前
uni-app:5 步接入 vite-plugin-uni-pages,用 <route> 自动生成 pages.json
前端
前端Hardy24 分钟前
告别 !important:现代 CSS 层叠控制指南,90% 的样式冲突其实不用它也能解
前端·vue.js·面试
前端Hardy28 分钟前
Vue 3 性能优化的 5 个隐藏技巧,第 4 个连老手都未必知道
前端·vue.js·面试
炫饭第一名31 分钟前
速通Canvas指北🦮——路径与形状篇
前端·javascript·程序员
无责任此方_修行中1 小时前
如何利用 pnpm 的安全控制功能防御 npm 供应链攻击
javascript·npm·node.js
DeathGhost1 小时前
CSS container容器查询
前端·css
JarvanMo1 小时前
Flutter:展示大段格式化文本的挑战
前端