vue项目上线后去除控制台所有console.log打印-配置说明

方式一

复制代码
npm  i   babel-plugin-transform-remove-console --save-dev

babel.config.js文件中添加

javascript 复制代码
// 然后在babel.config.js中添加判断
const prodPlugin = []

if (process.env.NODE_ENV === 'production') {
// 如果是生产环境,则自动清理掉打印的日志,但保留error 与 warn
  prodPlugin.push([
    'transform-remove-console',
    {
      // 保留 console.error 与 console.warn
      exclude: ['error', 'warn']
    }
  ])
}

module.exports = {
  'presets': [
    '@vue/app'
  ],
  'plugins': [
    [
      'import',
      {
        'libraryName': 'ant-design-vue',
        'libraryDirectory': 'es',
        'style': true
      },
      'ant-design-vue'
    ],
    ...prodPlugin
  ]
}

方式二

复制代码
npm i uglifyjs-webpack-plugin --save-dev

2.1 vue-cli3 生成环境去除console.log
在项目 目录vue.config.js

javascript 复制代码
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');

configureWebpack: {
        //注释console
        optimization: {
            minimizer: [
                new UglifyJsPlugin({
                    uglifyOptions: {
                        compress: {
                            // warnings: false,
                            drop_console: false, //注释console
                            drop_debugger: false,
                            pure_funcs: ['console.log'] //移除console
                        }
                    }
                })
            ]
        }
}

2.2 vue-cli2 生成环境去除console.log
项目build 下面webpack.prod.config.js 文件中

javascript 复制代码
plugins: [
    new webpack.DefinePlugin({
      'process.env': env
    }),
    new UglifyJsPlugin({
      uglifyOptions: {
        compress: {
          warnings: false,
          //drop_console  传递true以放弃对控制台的调用。*功能
          drop_console: true,
          // pure_funces 禁用console.log函数
          pure_funcs: ['console.log']
        }
      },
      sourceMap: config.build.productionSourceMap,
      parallel: true
]
相关推荐
可观测性用观测云17 分钟前
网站/接口可用性拨测最佳实践
前端
2503_9284115636 分钟前
12.26 小程序问题和解决
前端·javascript·微信小程序·小程序
灼华_38 分钟前
超详细 Vue CLI 移动端预览插件实战:支持本地/TPGZ/NPM/Git 多场景使用(小白零基础入门)
前端
借个火er38 分钟前
npm/yarn/pnpm 原理与选型指南
前端
总之就是非常可爱38 分钟前
vue3 KeepAlive 核心原理和渲染更新流程
前端·vue.js·面试
Mr_chiu39 分钟前
当AI成为你的前端搭子:零门槛用Cursor开启高效开发新时代
前端·cursor
over69740 分钟前
防抖与节流:前端性能优化的“双子星”,让你的网页丝滑如德芙!
前端·javascript·面试
red润43 分钟前
手把手封装Iframe父子单向双向通讯功能
前端·javascript·vue.js
gustt44 分钟前
JavaScript 闭包实战:手写防抖与节流函数,优化高频事件性能
前端·javascript·面试
青瓜达利园1 小时前
react hook注意事项
前端