vue 图片压缩

  • 使用image-conversion实现图片压缩到指定大小
// 导入
import * as imageConversion from 'image-conversion'

/**
  * 压缩小图到100kb
 */
compressImg(file) {
  console.log('file: ', file)
  return new Promise((resolve, reject) => {
    if (file.size / 1024 <= 100) {
      resolve(file)
    } else {
      try {
        imageConversion.compressAccurately(file, { size: 100, width: 500 }).then(result => {
          result = new File([result], file.name, { type: file.type, lastModified: Date.now() }) // blob转file
          resolve(result)
        })
      } catch (error) {
        console.log('compressImg error', error)
        resolve(file)
      }
    }
  })
}
  • 这里的指定大小,只会压缩到指定大小左右,不会非常精准,width需要根据size调整
posted @   jiazq  阅读(113)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示