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
]
相关推荐
我是若尘5 小时前
用 Git Worktree 同时开多个需求,不用来回 stash
前端
IT_陈寒5 小时前
Vue的v-for为什么不加key也能工作?我差点翻车
前端·人工智能·后端
小碗羊肉5 小时前
【JavaWeb | 第十二篇】项目实战——登录功能
java·前端·数据库
一个处女座的程序猿O(∩_∩)O5 小时前
如何保持nginx配置与前端打包dist的路径保持一致、解决页面刷新白屏以及页面跳转问题
运维·前端·nginx
JoyGqz6 小时前
Vue 2 EOL 之后还在跑生产?这个开源安全分支已修主流 CVE,一行依赖即可接入
vue.js
zz5886 小时前
面试官问"JS的类型"时,到底想听到什么?
javascript
gjwjuejin6 小时前
全埋点技术方案深度剖析:从事件代理到无痕采集的完整实现
javascript
十有八七6 小时前
AI 开发,本质是一场文档的生命周期管理
前端·人工智能
Lkstar6 小时前
Vue 3 Composition API 进阶:自定义 Hooks 与 provide/inject 的高级玩法
vue.js·面试
Hyyy6 小时前
普通前端自救记录——第0周
前端