当前位置: 代码网 > it编程>前端脚本>Vue.js > Vue生产环境如何自动屏蔽console

Vue生产环境如何自动屏蔽console

2024年06月10日 Vue.js 我要评论
vue生产环境自动屏蔽console背景在开发中打的log可能会忘记删除导致发上生产版本后有log打出为了保证生产环境不受这种影响所以在生产环境时自动屏蔽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中增加这段代码

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

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

发表评论

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