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%

相关推荐
16年上任的CTO2 天前
一文大白话讲清楚webpack基本使用——11——chunkIds和runtimeChunk
前端·webpack·node.js·chunksid·runtimechunk
Orange3015112 天前
【自己动手开发Webpack插件:开启前端构建工具的个性化定制之旅】
前端·javascript·webpack·typescript·node.js
小鱼神10243 天前
自动扣webpack框架演示 | 某书 x-xray-traceid 签名算法分析记录
webpack·js逆向·扣代码·xhs
16年上任的CTO4 天前
一文大白话讲清楚webpack基本使用——6——热更新及其原理
前端·webpack·node.js·热更新·hmr·热重载
16年上任的CTO4 天前
一文大白话讲清楚webpack基本使用——1——完成webpack的初步构建
前端·webpack·node.js
Nejosi_念旧4 天前
包文件分析器 Webpack Bundle Analyzer
前端·webpack·node.js
fechild4 天前
npm和webpack学习
学习·webpack·npm
16年上任的CTO4 天前
一文大白话讲清楚webpack基本使用——2——css相关loader的配置和使用
前端·webpack·node.js·sass-loader·css-loader·style-loader
16年上任的CTO4 天前
一文大白话讲清楚webpack基本使用——4——vue-loader的配置和使用
前端·javascript·webpack·ecmascript·vue-loader·vueloaderplugin