@docusaurus/lqip-loader
Low Quality Image Placeholders (LQIP) loader for webpack.
Installation
npm install --save-dev @docusaurus/lqip-loader
Example
Generating Base64 for a jpeg image imported in your JS bundle:
The large image file will be emitted & only 400byte of Base64 (if set to true in the loader options) will be bundled.
webpack.config.js
{
test: /\.jpe?g$/,
loaders: [
{
loader: '@docusaurus/lqip-loader',
options: {
path: '/media',
name: '[name].[ext]',
}
}
]
test: /\.(png|jpe?g)$/,
loaders: [
'@docusaurus/lqip-loader',
{
loader: 'url-loader',
options: {
limit: 8000
}
}
]
}
your-app-module.js
import banner from './images/banner.jpg';
console.log(banner.preSrc);
console.log(banner.src);
Important note
To save memory and improve GPU performance, browsers (including Chrome started from 61.0.3163.38) will now render a slightly more crisp or pixelated Base64 encoded images. If you want the blur to be very intense (smooth), here's a fix!
img {
filter: blur(25px);
}
More history about the issue can be found here and here.
Credits
This package has been imported from @endiliey/lqip-loader
which was a fork of the original lqip-loader
created exclusively for Docusaurus.