当前位置: 代码网 > it编程>前端脚本>Vue.js > vue-cli2,vue-cli3,vite 生产环境去掉console.log

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

2024年05月26日 Vue.js 我要评论
console.log一般都是在开发环境下使用的,在生产环境下需要去除,如果手动删除未免也太累了,我们可以用插件对于具体环境全局处理。vue-cli2项目build 下面webpack.prod.co

console.log一般都是在开发环境下使用的,在生产环境下需要去除 ,如果手动删除未免也太累了,我们可以用插件对于具体环境全局处理。

vue-cli2

项目build 下面webpack.prod.config.js 文件中:

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
    }),
     
    ......
]

vue-cli3

vue.config.js 里配置.

configurewebpack: config => {
    //生产环境取消 console.log
    if (process.env.node_env === 'production') {
      config.optimization.minimizer[0].options.terseroptions.compress.drop_console = true
    }
  },

 如果生产环境的文件中node_env  自定义,不是production,上述代码或报错,会显示找不到minimizer, 所以生产环境的node_env 尽量设置为production

生产环境node_env  自定义或者为production,都可以用下面的代码

const uglifyjsplugin = require('uglifyjs-webpack-plugin');
 
configurewebpack: config => {
    //生产环境取消 console.log
    if (process.env.node_env === 'prod') {
        optimization: {
            minimizer: [
                new uglifyjsplugin({
                    uglifyoptions: {
                        compress: {
                            // warnings: false,
                            drop_console: true, //注释console
                            drop_debugger: true,
                            pure_funcs: ['console.log'] //移除console
                        }
                    }
                })
            ]
        }
    }
  },

vite

1.build.minify为terser时(terser需要npm单独安装):

npm add -d terser

vite.config.ts  里配置.

import { defineconfig } from 'vite'
export default defineconfig( { 
...
    build : {
        minify : 'terser' ,
        terseroptions : {
            compress : {
                drop_console : true ,
                drop_debugger : true ,
            } ,
        } , 
    } ,
...
} )

2. build.minify默认为esbuild时:

    build : {
        esbuild: {
            drop: mode === 'production' ? ['console', 'debugger'] : []
        },
    }

到此这篇关于vue-cli2,vue-cli3,vite 生产环境去掉console.log的文章就介绍到这了,更多相关vue 生产环境去掉console.log内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网! 

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com