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

server/2025/1/30 7:51:33/

文章目录

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

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

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

  • 第一篇:
  • 一文大白话讲清楚啥是个webpack
  • 第二篇:
  • 一文大白话讲清楚webpack基本使用——1——完成webpack的初步构建
  • 第三篇
  • 一文大白话讲清楚webpack基本使用——2——css相关loader的配置和使用
  • 第四篇
  • 一文大白话讲清楚webpack基本使用——3——图像相关loader的配置和使用
  • 第五篇
  • 一文大白话讲清楚webpack基本使用——4——vue-loader的配置和使用
  • 第六篇
  • 一文大白话讲清楚webpack基本使用——5——babel的配置和使用
  • 第七篇
  • 一文大白话讲清楚webpack基本使用——6——热更新及其原理
  • 第八篇
  • 一文大白话讲清楚webpack基本使用——7——代码分离和懒加载
  • 第九篇
  • # 一文大白话讲清楚webpack基本使用——8——开发环境和生产环境的配置和区别
  • 第十篇
  • 一文大白话讲清楚webpack基本使用——9——预加载之prefetch和preload以及webpackChunkName的使用
  • 第十一篇
  • 一文大白话讲清楚webpack基本使用——10——使用CDN优化加载速度
  • 第十二篇
  • 一文大白话讲清楚webpack基本使用——11——chunkIds和runtimeChunk
  • 第十三篇
  • 一文大白话讲清楚webpack基本使用——12——文件指纹和缓存机制
  • 第十四篇
  • 一文大白话讲清楚webpack基本使用——13——Js代码压缩
  • 第十五篇
  • 一文大白话讲清楚webpack基本使用——14——CSS代码压缩
  • 第十六篇
  • 一文大白话讲清楚webpack基本使用——15——HTML代码压缩
  • 然后看本篇,图片压缩

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来进行图片压缩

npm install image-webpack-loader
  • 配置
{loader:'image-webpack-loader',options:{mozjpg:{progressive:true,//压缩算法,采用渐进式,progressive,也可以是基线式Baselinequality:65//输出质量,jpg一般建议不低于60}}
}

在这里插入图片描述

  • 我们重新构建,发现构建后的图片变小了,成了674KB
    在这里插入图片描述

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

{loader:'image-webpack-loader',options:{mozjpg:{progressive:true,//压缩算法,采用渐进式,progressive,也可以是基线式Baselinequality: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}}
}

webpackloader_97">4. image-webpack-loader压缩原理

  • image-webpack-loader内部其实是用Imagemin库来实现的
  • 比如在压缩png时,使用pngquant,通过将图片转换为具有alpha通道的更高效的8为png,减小文件体积;或者使用pngcrush,通过尝试不同的压缩级别和png过滤方法来降低PNG IDAT数据流的大小

http://www.ppmy.cn/server/163447.html

相关文章

Android Studio 新版本24.2.2 运行后自动切到 LogCat

最近更新了 Android studio 版本,发现有个问题: 每次 Run app 之后。都会自动切换到 run 标签。这让我非常不习惯。我个人习惯在app 运行后查看Logcat 最后靠 deepSeek 找到一种解决方案: Android Studio 中截图如下:

【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.20 极值追踪:高效获取数据特征的秘诀

1.20 极值追踪:高效获取数据特征的秘诀 1.20.1 目录 #mermaid-svg-RBxy2YCCN23ydzFu {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-RBxy2YCCN23ydzFu .error-icon{fill:#552222;}#mermaid-svg-RBxy2YC…

使用 Python 和 Tesseract 实现验证码识别

验证码识别是一个常见且实用的技术需求,尤其是在自动化测试和数据采集场景中。通过开源 OCR(Optical Character Recognition,光学字符识别)工具 Tesseract,结合 Python 的强大生态,我们可以高效实现验证码识…

从Stargate看全球科技变局与中国IT互联网的破局之路

从Stargate看全球科技变局与中国IT互联网的破局之路 科技新势力:Stargate 的诞生 在科技发展的长河中,每一次巨头间的携手都宛如一颗投入湖面的巨石,激起千层浪。软银、NVIDIA、Oracle 共同组建 Stargate 公司这一事件,无疑是 AI 领域的一场 “超级风暴”。美国当地时间 2025…

【故障诊断】量子粒子群优化极限学习机实现乳腺癌诊断,(QPSO-ELM)数据分类

1.简介 本文采用量子粒子群优化极限学习机实现乳腺癌诊断,极限学习机(ELM)用来训练单隐藏层前馈神经网络(SLFN)与传统的SLFN训练算法不同,极限学习机随机选取输入层权重和隐藏层偏置,输出层权重…

css之多边形 clip-path

平行四边形 clip-path: polygon(25% 0, 75% 0, 100% 0%, 75% 100%, 0% 100%, 0 100%);平行四边形图片展示 多边形 clip-path: polygon(10px 0,100% 0,100% calc(100% - 10px),calc(100% - 10px) 100%,0 100%, 0 10px);多边形图片展示

Python 数据清洗与处理常用方法全解析

在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战。本文总结了多种数据清洗与处理方法:缺失值处理包括删除缺失值、固定值填充、前后向填充以及删除缺失率高的列;重复值处理通过删除或标记重复项解决数据冗余问题&#xff1…

学术总结Ai Agent中firecrawl(大模型爬虫平台)的超简单的docker安装方式教程

之前开源了学术总结ai agent,但是对非计算机专业来说,门槛有点高,再加上docker hub镜像被屏蔽,更是不容易上手啊。也有考虑用dify或者扣子去复刻一个,但是从专业用户的角度出发通过界面来拖拽配置实在是不高效&#xf…