在vue.config.js中优化webpack配置的方法(持续更新)

前言:

在日常开发中我们离不开打包工具webpack,但是不同的配置会影响我们项目的运行构建时间,也会影响打包之后项目包的大小,这篇文章记录一下我使用过的可以优化webpack的配置。

注:以本专栏上篇文章里面的vue.config.js为基础,去加配置

一、压缩图片

1、先下载依赖

复制代码
npm install --save-dev image-webpack-loader

2、在vue.config.js的module.exports上面先定义设置值

①默认设置:(4M的图片使用默认设置压缩成1.4M)

javascript 复制代码
const defaultOptions = {
  bypassOnDebug: true,
};

②自定义设置

javascript 复制代码
 const customOptions = {
      mozjpeg: {
        progressive: true,
        quality: 50
      },
      optipng: {
        enabled: true,
      },
      pngquant: {
        quality: [0.5, 0.65],
        speed: 4
      },
      gifsicle: {
        interlaced: false,
      },
      // 不支持WEBP就不要写这一项
      webp: {
        quality: 75
      }
  }

3、在chainWebpack中加入配置:

javascript 复制代码
chainWebpack: config => {
 
    config.module.rule('images') 
        .test(/\.(gif|png|jpe?g|svg)$/i)
        .use('image-webpack-loader')
        .loader('image-webpack-loader')
        .options(customOptions)
        .end() 
 
  }

options中可以切换使用默认还是自定义

二、公共代码抽离:

在configureWebpack加入配置:

javascript 复制代码
configureWebpack: (config) => {
    config.optimization = {
      splitChunks: {
        cacheGroups: {
          vendor: {
            chunks: "all",
            test: /node_modules/,
            name: "vendor",
            minChunks: 1,
            maxInitialRequests: 5,
            minSize: 0,
            priority: 100,
          },
          common: {
            chunks: "all",
            test: /[\\/]src[\\/]js[\\/]/,
            name: "common",
            minChunks: 2,
            maxInitialRequests: 5,
            minSize: 0,
            priority: 60,
          },
          styles: {
            name: "styles",
            test: /\.(sa|sc|c)ss$/,
            chunks: "all",
            enforce: true,
          },
          runtimeChunk: {
            name: "manifest",
          },
        },
      },
    };
}

三、对代码进行压缩,并移除控制台输出

1、先下载依赖

javascript 复制代码
npm install uglifyjs-webpack-plugin --save-dev

2、在vue.config.js的第一行引入依赖

javascript 复制代码
const UglifyPlugin = require("uglifyjs-webpack-plugin");

3、在configureWebpack中加入配置:

javascript 复制代码
 config.plugins.push(
      new UglifyPlugin({
        uglifyOptions: {
          //生产环境自动删除console
          compress: {
            drop_debugger: true,
            drop_console: true,
            pure_funcs: ["console.log"],
          },
        },
        sourceMap: false,
        parallel: true,
      })
    );
相关推荐
我是伪码农几秒前
随机点名案例
前端·css·css3
徐_三岁3 分钟前
Windows 下 pnpm dev 报错:spawn esbuild.exe ENOENT(pnpm workspace / monorepo)
前端
亮子AI6 分钟前
【npm】如何创建自己的npm私有仓库?
前端·npm·node.js
JS_GGbond7 分钟前
前端Token无感刷新:让用户像在游乐园畅玩一样流畅
前端
用户8168694747258 分钟前
Context API 的订阅机制与性能优化
前端·react.js
用户49394095229359 分钟前
Function.prototype.bind实现
前端
用户841794814569 分钟前
vue 甘特图 vxe-gantt 任务里程碑和依赖线的使用
vue.js
AAA阿giao10 分钟前
Vue3 调用 Coze 工作流:从上传宠物照到生成冰球明星的完整技术解析
前端·vue.js·coze
异界蜉蝣11 分钟前
React Fiber架构:Diff算法的演进
前端·react.js·前端框架
追梦_life12 分钟前
localStorage使用不止于getItem、setItem、removeItem
前端·javascript