vue cli3 优化配置生产去除console.log - from UglifyJs `warnings` is not a supported option

本文解决VueCLI3.x配置生产环境移除console.log的错误,介绍使用TerserWebpackPlugin替代UglifyJSPlugin的方法,实现生产环境构建时移除console日志。

使用 vue cli 3.x 配置生产去除 console.log 时出现了报错,如下,

  1. 写法一:
// vue.config.js

module.exports = {
    optimization: {
      minimizer: [
        new UglifyJsPlugin({
          uglifyOptions: {
            compress: {
              warnings: false,
              drop_console: true,//console
              drop_debugger: false,
              pure_funcs: ['console.log']//移除console
            }
          }
        })
      ]
    }
 }

出现报错 UglifyJs
DefaultsError: warnings is not a supported option

在这里插入图片描述

  1. 写法二:
// vue.config.js

module.exports = {
  configureWebpack: config => {
    if (process.env.NODE_ENV === 'production') {
      config.plugins.push(
        new UglifyJsPlugin({
          uglifyOptions: {
            compress: {
              warnings: false,
              drop_debugger: true, // console
              drop_console: true,
              pure_funcs:['console.log'] // 移除console
            },
          },
          sourceMap: false,
          parallel: true,
        })
      )
    }
  },
}

出现报错 warnings is not a supported option
在这里插入图片描述
可见使用 uglifyjs-webpack-plugin 在这里无法实现去除控制台的信息。

使用 terser-webpack-plugin 代替,实现生产去除 console.log

// vue.config.js

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
            }
          },
        }),
      ]
    }
  },
}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值