参考一篇博主的文章

js图片压缩(compressorjs) - 简书

1、封装

文档地址https://github.com/fengyuanchen/compressorjs

npm install compressorjs
import Compressor from 'compressorjs';

/**
 * @param image 图片
 * @param backType 需要返回的类型blob,file
 * @param quality 图片压缩比 0-1,数字越小,图片压缩越小
 * @returns
 */
export default function ImageCompressor(image, backType, quality) {
    return new Promise((resolve, reject) => {
        new Compressor(image, {
            quality: quality || 0.6,
            success(result) {
                let file = new File([result], image.name, { type: image.type })

                if (!backType || backType == 'blob') {
                    resolve(result)
                } else if (backType == 'file') {
                    resolve(file)
                } else {
                    resolve(file)
                }
            },
            error(err) {
                console.log('图片压缩失败---->>>>>', err)
                reject(err)
            }
        })
    })
}

 2、调用

   async getUrl(file) { //file是文件数组
      //......
      const formData = new FormData();
      for (let i = 0; i < file.length; i++) {
        //对图片进行压缩
        let newImg = await ImageCompressor(file[i], 'file', 0.6);
        formData.append('file', newImg);
      }

      multipleFiles(formData, config).then((res) => {
          //.........
      })

    },

只支持压缩imge/jpeg 和 image/webp 图像

上传png格式的图片不能压缩

上传jpeg格式的图片可以压缩

Logo

前往低代码交流专区

更多推荐