advanced-image-loader
Advanced webpack2 image loader with support for image resizing, srcset and inlined placeholder.
Thanks to sharp it's blazing fast (see benchmars)!
Install
npm install advanced-image-loader --save-dev
Usage
Require in your javascript
import image from `advanced-image-loader!image.jpg?width=400
&quality=90
&placeholder=32
&srcset[]=200&srcset[]=400&srcset[]=800`;
{
"src": "test-400@90",
"width": 400,
"height": 225,
"srcset": "test-200@90 200w, test-400@90 400w, test-800@90 800w",
"placeholder": {
"src": "",
"width": 32,
"height": 18
},
"images": [
{
"src": "test-200@90",
"width": 200,
"height": 113
},
{
"src": "test-400@90",
"width": 400,
"height": 225
},
{
"src": "test-800@90",
"width": 800,
"height": 450
}
]
};
image.toString() === "test-400@90"
or css
.image {
background: url('advanced-image-loader!image.jpg');
}
.imageLQ {
background: url('advanced-image-loader!image.jpg?quality=30');
}
@media (max-width: 480px) {
.image {
background: url('advanced-image-loader!image.jpg?width=480');
}
}
Configuration
All the parameter can be set as webpack rule option or defined on a per resource base using resourceQuery parameters.
In case a configuration parameter is defined in both location the resourceQuery has higher priority.
width: integer or 'original'
default: 'original'
: define the output width of the 'main' imagesrcset: array of 'widths' (integer or 'original')
: if specified define the width of all the images in the srcsetformat: string
default: 'jpeg'
: define the output format of the images (valid values are jpeg
, png
, tiff
, webp
)quality: integer
default: '95'
: define the compression quality (ignored if format is png
)placeholder: integer
: if specified define the width of the image used as placeholder and inlined as data URI
Examples
** webpack.config.js options **
module.exports = {
entry: {...},
output: {...},
module: {
rules: [
{
test: /\.(jpg)$/i,
loader: 'advanced-image-loader',
options: {
width: 1280,
srcset: [320, 640, 960, 1280, 1920],
quality: 90,
placeholder: 32
}
}
]
}
}
** resourceQuery overrides **
see here for more information about resourceQuery syntax
import image from './image.jpg';
import imageLQ from './image.jpg?quality=25&-srcset&-placeholder';
import imageHighRes from './image.jpg?width=2048&-srcset&-placeholder';
Based and inspired by: