The main repository seems not like accepting PR's since a long time hence this fork, this may evaporate if the main repo is active again
Browser Image Compression
Javascript module to be run in the web browser for image compression.
Features
- You can use this module to compress jpeg and png image by reducing resolution or storage size before uploading to application server to save bandwidth.
- Multi-thread (web worker) non-blocking compression are supported through options.
Install
You can download imageCompression from the dist folder. Alternatively, you can install it via yarn or npm
npm install browser-image-compression --save
or
yarn add browser-image-compression
or use a CDN like delivrjs:
https://cdn.jsdelivr.net/npm/browser-image-compression@1.0.5/dist/browser-image-compression.js
or
https://cdn.jsdelivr.net/npm/browser-image-compression@latest/dist/browser-image-compression.js
How to use this module in your project?
Use as ES module
(can be used in framework like React, Angular, Vue etc)
(work with bundler like webpack and rollup)
;
or
In html file
API
Main function
// you should provide one of maxSizeMB, maxWidthOrHeight in the optionsconst options = maxSizeMB: number // (default: Number.POSITIVE_INFINITY) maxWidthOrHeight: number // compressedFile will scale down by ratio to a point that width or height is smaller than maxWidthOrHeight (default: undefined) useWebWorker: boolean // optional, use multi-thread web worker, fallback to run in main-thread (default: true) maxIteration: number // optional, max number of iteration to compress the image (default: 10) : Promise<File>
Helper function
- for advanced user only, most user won't need to use the helper functions
imageCompression: Promise<base64 encoded string>imageCompression: Promise<File>imageCompression: Promise<HTMLImageElement>imageCompression: HTMLCanvasElementimageCompression: Promise<ImageBitmap | HTMLImageElement HTMLCanvasElement>imageCompression: Promise<File|Blob>imageCompression: Promise<number> // based on https://stackoverflow.com/a/32490603/10395024
Usage
async await syntax:
{ const imageFile = eventtargetfiles0; console; // true console; var options = maxSizeMB: 1 maxWidthOrHeight: 1920 useWebWorker: true try const compressedFile = await ; console; // true console; // smaller than maxSizeMB await ; // write your own logic catch error console; }
Promise.then().catch() syntax:
{ var imageFile = eventtargetfiles0; console; // true console; var options = maxSizeMB: 1 maxWidthOrHeight: 1920 useWebWorker: true ;}
Demo / Example
open https://donaldcwl.github.io/browser-image-compression/example/basic.html
or check the "example" folder in this repo
Browsers support
IE / Edge |
Firefox |
Chrome |
Safari |
Opera |
Chrome for Android |
---|---|---|---|---|---|
IE10, IE11, Edge | last 2 versions | last 2 versions | last 2 versions | last 2 versions | last 2 versions |
Contribution
- fork the repo and git clone it
- run
npm run watch
# it will watch code change in lib/ folder and generate js in dist/ folder - add/update code in lib/ folder
- try the code by opening example/development.html which will load the js in dist/ folder
- add/update test in test/ folder
npm run test
- push to your forked repo on github
- make a pull request to this repo