移除生产环境console.log

本文介绍了在项目开发中如何通过第三方插件解决console.log日志在生产环境中的问题。在开发环境,console.log用于调试,但上线时需移除。文章提到了两种解决方案:一是使用babel-plugin-transform-remove-console插件,通过配置babel.config.js文件在生产环境移除console.log;二是利用terser-webpack-plugin,配置vue.config.js以达到同样目的。
业务需求:

随着项目开发迭代,代码越来越多,在开发环境时,大多需要console.log打印日志做相应的处理,还有就是通过console.log()日志的状态来定位bug的位置。协同开发过程中,每个开发成员都也有可能打印console.log,有时候可能忙于疏忽,忘记注释掉打印的日志,也有肯能打印的信息是一些涉及用户个人信息安全的日志信息。当上生产环境时,这些日志信息都不应该出现在控制台。若是一个一个去找,去注释代码,这肯定不现实。
现在可以通过第三方插件来统一处理console.log日志的打印,有了第三方插件的加持,就可以不用担心生产环境打印日志的问题了。

插件使用:
  • 安装插件
yarn add babel-plugin-transform-remove-console -D
// or
npm install babel-plugin-transform-remove-console --save-dev

:可以通过yarn或npm来安装依赖;-D 等价于 --save-dev,意思是将依赖安装在开发环境中。

  • 方式一:
const plugins = ["@vue/babel-plugin-transform-vue-jsx"];
// 生产环境移除console
if (process.env.NODE_ENV === "production") {
	plugins.push("transform-remove-console");
}

module.exports = {
	plugins: plugins,
	presets: ["@vue/cli-plugin-babel/preset"]
};
  • 方式二:
module.exports = {
	presets: ["@vue/cli-plugin-babel/preset"],
  // 生产环境移除console
	env: {
		production: {
			plugins: ["transform-remove-console"]
		}
	}
};
  • 方式三:
const IS_PROD = ["production","prod"].includes(process.env.NODE_ENV);

const plugins = [];

module.exports = {
   // 生产环境移除console
  plugins: plugins,
	presets: ["@vue/cli-plugin-babel/preset"]
};
方案二
  • 安装插件
yarn add terser-webpack-plugin -D
// or
npm install terser-webpack-plugin --save-dev

方案一方案二配置移除console.log()是在babel.config.js中配置的。

  • 使用方法
const TerserPlugin = require("terser-webpack-plugin");

module.exports = {
  configureWebpack: {
    minimizer: [
      new TerserPlugin({
        terserOptions: {
          compress: {
            pure_funcs: ["console.log"]
          }
        }
      })
    ]
  }
};

:此次代码配置是在vue.config.js中配置的。

【SCI复现】含可再生能源与储能的区域微电网最优运行:应对不确定性的解鲁棒性与非预见性研究(Matlab代码实现)内容概要:本文围绕含可再生能源与储能的区域微电网最优运行展开研究,重点探讨应对不确定性的解鲁棒性与非预见性策略,通过Matlab代码实现SCI论文复现。研究涵盖多阶段鲁棒调度模型、机会约束规划、需求响应机制及储能系统优化配置,结合风电、光伏等可再生能源出力的不确定性建模,提出兼顾系统经济性与鲁棒性的优化运行方案。文中详细展示了模型构建、算法设计(如C&CG算法、大M法)及仿真验证全过程,适用于微电网能量管理、电力系统优化调度等领域的科研与工程实践。; 适合人群:具备一定电力系统、优化理论和Matlab编程基础的研究生、科研人员及从事微电网、能源管理相关工作的工程技术人员。; 使用场景及目标:①复现SCI级微电网鲁棒优化研究成果,掌握应对风光负荷不确定性的建模与求解方法;②深入理解两阶段鲁棒优化、分布鲁棒优化、机会约束规划等先进优化方法在能源系统中的实际应用;③为撰写高水平学术论文或开展相关课题研究提供代码参考和技术支持。; 阅读建议:建议读者结合文档提供的Matlab代码逐模块学习,重点关注不确定性建模、鲁棒优化模型构建与求解流程,并尝试在不同场景下调试与扩展代码,以深化对微电网优化运行机制的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值