vue-cli3/webpack打包时去掉console.log调试信息


前言

开发环境下,console.log调试信息,有助于我们找到错误,但在生产环境,不需要console.log打印调试信息,所以打包时需要将console.log调试信息过滤清除。


一、terser-webpack-plugin是什么?

该插件使用 terser 来压缩 JavaScript。

terser-webpack-plugin是用来压缩 js 的,开发环境的console.log、debugger 等用来调试的信息,打包时都需要这个插件。

webpack v5 开箱即带有最新版本的 terser-webpack-plugin。如果你使用的是 webpack v5 或更高版本,同时希望自定义配置,那么仍需要安装 terser-webpack-plugin。如果使用 webpack v4,则必须安装 terser-webpack-plugin v4 的版本。

如果是vue-cli3的话,默认安装了terser-webpack-plugin,如果没安装下面可以直接复制。

npm install terser-webpack-plugin --save-dev

二、使用配置

vue-cli项目

vue-cli项目默认是基于webpack打包工具的,但是项目的配置文件是vue.config.js,其他项目在webpack.config.js配置
在这里插入图片描述
代码配置如下:

//vue.config.js
const TerserPlugin = require('terser-webpack-plugin')


module.exports = {
   
  configureWebpack: {
   
    optimization: {
   
      minimizer: [
        new TerserPlugin({
   
          terserOptions: {
   
            compress: {
   
              drop_console: true // 注释console
            }
          }
        })
      ]
    }
  },
}

如果上面的配置文件无效可以试试下面的配置,参数不同,可能是因为版本不同,我的是webpack4,vue-cli3.

//vue.config.js
const TerserPlugin = require('terser-webpack-plugin')
module.exports = {
   
configureWebpack: {
   
    optimization: {
   
      minimizer: [
        new TerserPlugin({
   
          terserOptions: {
   
            ecma: undefined,
            warnings: false,
            parse: {
   },
            compress: {
   
              drop_console: true,
              drop_debugger: false,
              pure_funcs: ['console.log'] // 移除console
            }
          },
        }),
      ]
    }
  }
 },

相关推荐

  1. vue-cli2,vue-cli3,vite 生产环境去掉console.log

    2023-12-30 10:48:04       111 阅读
  2. Webpack打包vue项目

    2023-12-30 10:48:04       52 阅读
  3. webpack 构建自己的vue-cli

    2023-12-30 10:48:04       40 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-30 10:48:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-30 10:48:04       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-30 10:48:04       82 阅读
  4. Python语言-面向对象

    2023-12-30 10:48:04       91 阅读

热门阅读

  1. 如何准备 Azure 信息保护云退出计划

    2023-12-30 10:48:04       55 阅读
  2. 【Linux】Ubuntu22.04版本下实现gcc版本的快速切换

    2023-12-30 10:48:04       66 阅读
  3. PyTorch中的 Dataset、DataLoader 和 enumerate()

    2023-12-30 10:48:04       56 阅读
  4. Linux添加一个指令代替指定指令

    2023-12-30 10:48:04       56 阅读
  5. 79. Word Search

    2023-12-30 10:48:04       66 阅读
  6. 蓝桥杯python比赛历届真题99道经典练习题 (8-12)

    2023-12-30 10:48:04       51 阅读
  7. 结构体--高考数组

    2023-12-30 10:48:04       66 阅读
  8. STM32传输FPGA业务

    2023-12-30 10:48:04       56 阅读