Advanced webpack2 image loader with support for image resizing, srcset and inlined placeholder. Thanks to sharp it's blazing fast (see benchmars)!
npm install advanced-image-loader --save-dev
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');
}
}
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 iswebp
ortiff
)default: false
placeholder: 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 thecontext
query 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
hashType
s, i. e.sha1
,md5
,sha256
,sha512
- other
digestType
s, i. e.hex
,base26
,base32
,base36
,base49
,base52
,base58
,base62
,base64
- and
length
the 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
** 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';