webpack 压缩图片

压缩前:

压缩后:

压缩后基本上是压缩了70-80%左右

1.依赖版本及配置

"imagemin-webpack-plugin": "^2.4.2",

"imagemin-mozjpeg": "^7.0.0",

"imagemin-pngquant": "^5.0.1",

"webpack": "^3.6.0", //基于webpack3的项目
plugins: [

new ImageminPlugin({

pngquant: ImageminPngquant({

quality: [0.65, 0.90], // 压缩级别,范围0-1

speed: 4, //速度,范围1-11

}),

test: /\.(jpe?g|png|gif|svg)(\?.*)?$/i,

optipng: {

optimizationLevel: 7 // 0-7的优化级别

},

gifsicle: {

interlaced: true, // 是否隔行扫描gif进行模糊效果

optimizationLevel: 3 // 0-3的优化级别

},

jpegtran: {

progressive: true, // 是否无损压缩

},

mozjpeg: {

quality: 65, // 图片质量,范围0-100

progressive: true // 是否启用渐进式编码

},

svgo: { //不需要可注释 "imagemin-svgo": "^11.0.1",

plugins: [

{ removeViewBox: false },

{ cleanupIDs: false }

// 可以添加更多SVGO插件配置

]

},

plugins: [

ImageminMozjpeg({

quality: 75,

progressive: true,

}),

],

}),

//其他配置

]

2.不同图片格式优缺点

jpeg/jpg

  • jpeg/jpg 压缩比还色彩不错 (web开发都使用这种格式)

  • jpeg/jpg的使用场景比较大的图 如轮播

  • jpeg/jpg的缺陷 比如logo不适合

png

  • png的优点(1.做透明的背景)

  • png的使用场景 :使用比较小的图片如icon等使用如logo等(需要纹理、线条等)

  • png 的缺陷(体积比较大,imagemin-pngquant针对png压缩设置60-85%左右)

  • imahemin-pngquant 工具压缩

webp

  • 可以用工具生成webp的格式,webp压缩出来的体积比png更小

  • 兼容性一般只支持80%

相关推荐
胡西风_foxww16 小时前
nextjs部署更新,Turbopack 和 Webpack 缓存冲突问题解决
缓存·webpack·react·nextjs·turbopack
Doris89316 小时前
【Node.js 】Node.js 与 Webpack 模块化工程化入门指南
前端·webpack·node.js
JohnsonXin17 小时前
一次线上白屏排查:静态 import 是如何悄悄破坏 Webpack 共享 Chunk 的
前端·webpack·node.js
2401_8442213217 小时前
在Webpack中打包编译和优化CSS及LESS文件的全面指南
css·webpack·less
Kinghiee3 天前
使用webpack构建vue3 ssr
前端·webpack·node.js·vue3ssr
北寻北爱4 天前
面试题-git+npm
vue.js·git·webpack·echarts
光影少年4 天前
Webpack的核心概念?常见优化手段?
前端·webpack·掘金·金石计划
好运yoo7 天前
在package.json中scripts这个配置的命令是什么意思
前端·webpack·json·vite·wepack