一文大白话讲清楚webpack基本使用——16——图片压缩

文章目录

  • 一文大白话讲清楚webpack基本使用------16------图片压缩
  • [1. 建议按文章顺序从头看,一看到底,豁然开朗](#1. 建议按文章顺序从头看,一看到底,豁然开朗)
  • [2. 为啥要压缩图片](#2. 为啥要压缩图片)
  • [3. 怎么压缩](#3. 怎么压缩)
  • [4. image-webpack-loader压缩原理](#4. image-webpack-loader压缩原理)

一文大白话讲清楚webpack基本使用------16------图片压缩

1. 建议按文章顺序从头看,一看到底,豁然开朗

2. 为啥要压缩图片

  • 一句话,因为大,加载慢,还耗费带宽,所以要压缩小

3. 怎么压缩

  • webpack中压缩图片我们常用image-webpack-loader,当然配合file-loader或者url-loader使用,先压缩在使用么,就好像style-loader和css-loader的先后顺序一样

  • 我们之前在第四篇文章一文大白话讲清楚webpack基本使用------3------图像相关loader的配置和使用讲webpack处理图片的时候再src/img下面放了一个index.jpg

  • 图片被构建后,生成了新的图片文件

  • 我们查看其大小发现是711KB

  • 这时候我们安装和配置image-webpack-loader来进行图片压缩

js 复制代码
npm install image-webpack-loader
  • 配置
js 复制代码
{
    loader:'image-webpack-loader',
    options:{
        mozjpg:{
            progressive:true,//压缩算法,采用渐进式,progressive,也可以是基线式Baseline
            quality:65//输出质量,jpg一般建议不低于60
        }
    }
}
  • 我们重新构建,发现构建后的图片变小了,成了674KB

  • 上面我们只配置了对jpg图片类型的压缩,我们还可以配置其他图片类型的压缩

js 复制代码
{
    loader:'image-webpack-loader',
    options:{
        mozjpg:{
            progressive:true,//压缩算法,采用渐进式,progressive,也可以是基线式Baseline
            quality:65//输出质量
        },
        optipng:{//专门用于优化PNG格式的配置
            enabled:true//是否开启
        },
        pngquant:{
            quality:[0.5,0.75],//设置png压缩质量范围为
            speed:4//配置压缩速度
        },
        gifslice:{// 将GIF文件分割成多个小文件
            interlaced:false,//是否使用隔行扫描技术来减少初始加载时间
            optimizationLevel:3,//优化级别
            slices:8//分成8块
        },
        webp:{
            quality:75
        }
    }
}

4. image-webpack-loader压缩原理

  • image-webpack-loader内部其实是用Imagemin库来实现的
  • 比如在压缩png时,使用pngquant,通过将图片转换为具有alpha通道的更高效的8为png,减小文件体积;或者使用pngcrush,通过尝试不同的压缩级别和png过滤方法来降低PNG IDAT数据流的大小
相关推荐
小磊哥er几秒前
【前端工程化】前端开发中的这些设计规范你知道吗
前端
江城开朗的豌豆1 分钟前
路由守卫:你的Vue路由‘保安’,全局把关还是局部盯梢?
前端·javascript·vue.js
Jinxiansen02119 分钟前
Vue 3 响应式核心源码详解(基于 @vue/reactivity)
前端·javascript·vue.js
OEC小胖胖5 小时前
去中心化身份:2025年Web3身份验证系统开发实践
前端·web3·去中心化·区块链
vvilkim6 小时前
Electron 进程间通信(IPC)深度优化指南
前端·javascript·electron
ai小鬼头8 小时前
百度秒搭发布:无代码编程如何让普通人轻松打造AI应用?
前端·后端·github
漂流瓶jz8 小时前
清除浮动/避开margin折叠:前端CSS中BFC的特点与限制
前端·css·面试
前端 贾公子8 小时前
在移动端使用 Tailwind CSS (uniapp)
前端·uni-app
散步去海边8 小时前
Cursor 进阶使用教程
前端·ai编程·cursor
清幽竹客8 小时前
vue-30(理解 Nuxt.js 目录结构)
前端·javascript·vue.js