当前位置: 首页 > news >正文

【减小图片打包体积】image-webpack-loader

场景:登录页背景图片体积过大,加载慢,影响用户体验。

压缩前:

压缩后:

实现步骤:

1、安装image-webpack-loader

npm install image-webpack-loader

2、添加webpack的loader配置,和plugin配置同级

module:{
      rules:[
        {
          test: /\.(gif|png|jpe?g|svg)$/i,
          use:[{
            loader:'image-webpack-loader',
            options:{
              mozjpeg: {
                progressive: true, 
                quality: 60, // JPG 输出的质量 一般60为可接受的
              },
              optipng: {
                enabled: true,
              },
              pngquant: {
                quality: [0.5, 0.65], // PNG 质量范围
                speed: 4,
              },
              gifsicle: {
                interlaced: false,// 优化GIF
              },
              webp: {
                quality: 75, // 转换为 webp
              },
            }
          }]
        }
      ]
    }

3、打包

npm run build:prod

期间报错,说是没有imagemin-mozjpeg这个moudle。(这一步看请情况,也许你不报这个错,根据报错去解决,少哪个包就安哪个包)

4、安装imagemin-mozjpeg

npm install imagemin-mozjpeg

5、再次打包,npm run build:prod

打开dist/static/img,找到对应图片,发现图片被成功压缩啦

相关文章:

  • MySQL--数据备份
  • 实时数据流处理利器:Apache Storm 在大数据中的应用
  • .Net中对称加密的实现
  • cJSON类型及type值详解
  • ECharts系列: Vue 中使用 ECharts 折线图时,怎么配置来实现默认隐藏某些图例,并在用户点击图例时显示或隐藏对应的数据系列
  • MySQL的事务
  • Springboot3.x集成Spring Batch 5.2.1
  • 面试经典150题·LeetCode26·删除有序数组中的重复项·Java
  • 18.redis基本操作
  • 内积相似系数——内积度量相似系数
  • html 列表循环滚动,动态初始化字段数据
  • Android 隐藏手势模式下输入法的BackButton和ImeSwitchButton
  • Vue项目中Vuex在util引入,断点存在default
  • EI复现:蜣螂优化算法变体合集上新,改进正弦算法引导的蜣螂优化算法
  • ts中 构造器
  • 23种设计模式-结构型模式-桥接器
  • 【CF】Day20——Codeforces Round 969 (Div. 2) C
  • STM32 CAN学习(一)
  • linux-- 0. C语言过、Java半静对、Python纯动和C++对+C
  • mapState 函数的用法
  • 北京最大做网站的公司/seo短期培训班
  • 网站建设必会的软件有哪些/网站单向外链推广工具
  • 合肥网站建设制作/站长之家备案查询
  • 大型网站频道的建设需多人协同开发/怎么样建一个网站
  • 做网站用哪个电脑/外贸网站seo优化
  • 网站名称及网址/南昌seo实用技巧