Vue生产环境如何自动屏蔽console
更新时间:2024年06月06日 15:09:56 作者:北长风
这篇文章主要介绍了Vue生产环境如何自动屏蔽console问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
Vue生产环境自动屏蔽console
背景
在开发中打的log可能会忘记删除导致发上生产版本后有log打出
为了保证生产环境不受这种影响
所以在生产环境时自动屏蔽console;
原理
在项目初始化的时候判断环境,如果是生产环境则把console的指向替换;
实现
在main.js里插入以下代码
// 屏蔽console
(function shieldConsole() {
if (process.env.NODE_ENV == "production") {
Reflect.ownKeys(console).map(key => {
if (typeof console[key] == "function") {
console[key] = () => {};
}
});
}
return;
})();- console是symbol类型所以需要用Object.getOwnPropertySymbols()、Reflect.ownKeys() 遍历
- 注意使用Reflect.ownKeys()遍历后会带一个symbol内置对象
- 把console的所有方法都改空函数就不会返回了
Vue打包后取消console
module.exports = {
chainWebpack(config) {
//delete console
config.optimization.minimizer('terser').tap((args) => {
args[0].terserOptions.compress.drop_console = true
return args
})
}
}vue.config.js中增加这段代码
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Vue3+Element Plus使用svg加载iconfont的处理方法
这篇文章主要介绍了Vue3+Element Plus使用svg加载iconfont的解决方案,本文详细介绍了如何在Element Plus中使用iconfont,简单的说就是要将其封装成SVG,并且支持动态修改颜色,需要的朋友可以参考下2022-08-08
vue beforeDestroy clearInterval清除定时器失效的解决
这篇文章主要介绍了vue beforeDestroy clearInterval清除定时器失效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-06-06
vue-cli项目中使用公用的提示弹层tips或加载loading组件实例详解
这篇文章主要介绍了vue-cli项目中使用公用的提示弹层tips或加载loading组件,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下2018-05-05
Vue-cli assets SubDirectory及PublicPath区别详解
这篇文章主要介绍了Vue-cli assets SubDirectory及PublicPath区别详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2020-08-08


最新评论