支持移动端的前端图片压缩库

目录

  • 支持移动端的前端图片压缩库
    • 说明
    • 使用方法
    • 选项
    • 例子
      • 接收图片路径压缩
      • 接收 `file` 对象压缩
      • 获取 `base64`
      • 获取 `blob`

支持移动端的前端图片压缩库

前段时间做移动端项目时遇到移动端选择图片上传的问题,在查看了网上的一些图片压缩套路后,简单整合了代码,可用于前端上传图片前的图片压缩处理,兼容PC、Android、iOS平台。
本项目已开源,地址:https://github.com/lyswhut/resizeImg

说明

用于前端上传图片前的图片压缩处理,兼容PC、android、ios平台。

本项目整合了 jpeg_encoder_basic.jsmegapix-image.js

demo地址:http://stsky.cn/demo/resizeimg/

当需要压缩大图(比如手机拍摄的图片)时本插件才会发挥作用。
注意:这只是简单的图片压缩,即把原图缩小比例后再通过canvas画出来,本插件对于需要把高分辨率(大图)压成低分辨率(小图)时才会起效果,不然可能会起到反效果(即压了反而变大),所以需要先判断图片大小再选择是否进行压缩处理。

使用方法

压缩后的文件在GitHub的dist文件夹里,直接引入压缩后的文件即可:

<script src="./js/resizeImg.min.js"></script>

选项

/**
 * 图片压缩
 * @param {String|Array|Object} imgs 图片路径字符串/图片路径数组/file对象/Blob对象
 * @param {Object} options
 * @param {Number} [options.width] 图片需要压缩的宽度,高度会跟随调整
 * @param {Number} [options.quality=0.8] 压缩质量,不压缩为1
 * @param {String} [options.type] 可选,需要返回的文件类型,如'image/jpeg'、'image/png'等
 * @param {Function} [options.success(result)] 完成的回调函数,若type有值,则返回blob,否则返回base64
 */

例子

接收图片路径压缩

__resizeImg('test.jpg', {
      width: 200,
      quality: 0.9,
      type: 'image/jpeg',
      success: function($Blob) {
        // formData.append("imgFile", $Blob, "file_" + new Date().getTime() + ".jpg");
        // ...
      }
    })

接收 file 对象压缩

var dom_input_file = document.querySelector('#file_1')
__resizeImg(dom_input_file.files[0], {
  width: 200,
  quality: 0.9,
  type: 'image/jpeg',
  success: function($Blob){
    // formData.append("imgFile", $Blob, "file_" + new Date().getTime() + ".jpg");
    // ...
  }
})

获取 base64

通过原图获取压缩后图片的 base64,可直接当做字符串传给后台

__resizeImg('test.jpg', {
  width: 200,
  quality: 0.9,
  success: function($base64){
    // resize image $base64
    // ...
  }
})

获取 blob

通过原图获取压缩后图片的 blob,可以把 blob 放进 FormData 里发给服务器

__resizeImg('test.jpg', {
  width: 200,
  quality: 0.9,
  type: 'image/jpeg',
  success: function($Blob){
    // formData.append("imgFile", $Blob, "file_" + new Date().getTime() + ".jpg"); 
    // ...
  }
})

好用的话请在GitHub给个star哦~

你可能感兴趣的:(前端)