This is the third day of my participation in the First Wenwen Challenge 2022.First challenge in 2022
introduce
I believe that many new partners in the development of the project, more than once used a lot of local picture resources, many are looking for online or computer software to compress the volume, of course, in fact, in webpack can carry out its compression optimization, Image-minimizer-webpack-plugin is a webpack image compression plugin that uses Imagemin to compress all images. So don’t worry about image sizes in the future, they can now be automatically optimized/compressed.
The installation
# NPM
npm install --save-dev image-minimizer-webpack-plugin
# Yarn
yarn add -D image-minimizer-webpack-plugin
Copy the code
use
To demonstrate this we will simply create an index.html, and in its logical script app.js we will put two native images, one PNG and one SVG.
// app.js
import "./assets/style.css"
const imgs = [require("./assets/01.png"),require("./assets/02.svg")];
imgs.forEach(src= >{
let img = document.createElement("img");
img.src = src;
document.getElementById("app").appendChild(img)
})
Copy the code
We then execute the YARN Build command to package and record the size of the two images after packaging.
Now, the business is about to begin.
Before we do this, we should be aware that this plugin can use two tools to optimize/generate images:
- Imagemin: Optimize your image by default because it is stable and works with all types of images
- Squoosh: works in experimental mode with.jpg,.jpeg,.png,.webp,.avif file types.
We are going to use Imagemin this time, so we need to pre-install its plug-in content.
-
The imagemin plugin is recommended for non-destructive optimization:
npm install imagemin-gifsicle imagemin-jpegtran imagemin-optipng imagemin-svgo --save-dev Copy the code
-
The imagemin plugin is recommended for non-destructive optimization:
npm install imagemin-gifsicle imagemin-mozjpeg imagemin-pngquant imagemin-svgo --save-dev Copy the code
Imagemin – MozJPEG and Imagemin – SvGo can be configured in lossless and lossy modes.
After the installation is complete, we do the following:
// webpack.config.js
const TARGET = process.env.npm_lifecycle_event;
const optimization = {
minimizer: []}if (TARGET.indexOf("build")! = -1) {
const ImageMinimizerPlugin = require("image-minimizer-webpack-plugin");
const imageMinimizerPlugin = new ImageMinimizerPlugin({
minimizer: {
implementation: ImageMinimizerPlugin.imageminMinify, // There are two modes: imageminMinify and squooshMinify
options: {
plugins: [["gifsicle", { interlaced: true }],
["jpegtran", { progressive: true }],
["optipng", { optimizationLevel: 5 }],
["svgo", {
plugins: [
'preset-default',
{
name: "removeViewBox".active: false}, {name: "addAttributesToSVGElement".params: {
attributes: [{ xmlns: "http://www.w3.org/2000/svg" }],
},
},
],
},
],
],
},
},
})
optimization.minimizer.push(imageMinimizerPlugin)
}
module.exports = {
// ...
module: {
rules: [
// ...
{
test: /\.(jpe? g|png|gif|svg)$/i,
type: "asset",
},
]
},
optimization
// ...
}
Copy the code
You can see that we first get the current directive through process.env.npm_lifecycle_event if we want to execute the package command. It only makes sense for us to finally compress (for now, this simple business scenario). And this plugin will be placed inside Optimization minimizer.
Note that the above code is written above SVGO9. If svGO 9 below requires extendDefaultPlugins as follows:
// svGo 9 below:
const { extendDefaultPlugins } = require("svgo");
["svgo", {plugins: extendDefaultPlugins([
// ...}]])Copy the code
Now we do the packaging again and see the following directory:
The exciting moment came when PNG became 1MB from 1.5MB and SVG was 4KB smaller. Of course, it is lossless compression, but if you want to make it smaller, you can manually change the value to lossy.
teasing
But to tell the truth, if you do a simple page application in fact, webpack automatic compression of images is ok, if the local image is very large and very large actually not suitable for automatic compression, because the wife time-consuming!!
There are imagemin- Jpegtran and Imagemin – GIFsicle these two plug-ins, sometimes can not download down, change the hosts configuration, scientific Internet access sometimes useless, but sometimes a time, the party.
conclusion
We briefly introduced the image-Minimizer-webpack-plugin today. If you want to build your own scaffolding to automatically process some local images, consider this plugin. Of course, today is only a scratch, there are more configurations and usage methods waiting for you to explore, such as filtering, you can go to the image-Minimizer-Webpack-plugin repository to explore.