advanced-image-loader
advanced-image-loader copied to clipboard
Advanced webpack2 image loader with support for image resizing, srcset and inlined placeholder. And it's blazing fast
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`;
// generates images
// [email protected]
// [email protected]
// [email protected]
// and image object is
{
"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 object toString return the main image src
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': define the output width of the 'main' imagedefault: 'original'srcset: array of 'widths' (integer or 'original'): if specified define the width of all the images in the srcsetformat: string: define the output format of the images (valid values arejpeg,png,tiff,webp)default: 'jpeg'quality: integer: define the compression quality (ignored if format ispng)default: '95'progressive: boolean: define if the generated image should be progressive (ignored if format iswebportiff)default: falseplaceholder: integer: if specified define the width of the image used as placeholder and inlined as data URIname: function or string: define the naming of the output filesdefault: '[name]-[width]@[quality]'- if a string is provided it will be interpolated and the following values will be replaced
[width]the width of the output image[quality]the configured quality[ext]the extension of the resource[name]the basename of the resource[path]the path of the resource relative to thecontextquery parameter or option.[folder]the folder of the resource is in.[emoji]a random emoji representation of the image[emoji:<length>]same as above, but with a customizable number of emojis[hash]the hash of the image[<hashType>:hash:<digestType>:<length>]optionally one can configure- other
hashTypes, i. e.sha1,md5,sha256,sha512 - other
digestTypes, i. e.hex,base26,base32,base36,base49,base52,base58,base62,base64 - and
lengththe length in chars
- other
- if a function is provided it will be called with a single object parameter structured as:
{ "buffer": <image data buffer? "info": { "format": string <format of the output image>, "width": integer <width of the output image>, "height": integer <height of the output image>, "channels": integer <number of collor channels of the output image>, "size": integer <filesize of the output image> }, "options": object <the configuration option>, "resourcePath": string <absolute path of the input image> }- if a string is provided it will be interpolated and the following values will be replaced
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
// only webpack rule options apply.
import image from './image.jpg';
// override previous configuration lowering output quality and disabling srcset and placeholder. only the main image, 1280px wide and 25% quality will be returned
import imageLQ from './image.jpg?quality=25&-srcset&-placeholder';
// generate additional image 2048px wide
import imageHighRes from './image.jpg?width=2048&-srcset&-placeholder';