next.js生产环境去掉console打印

next.js生产环境去掉console打印

为什么需要去掉console?

Console 对象用于 JavaScript 调试。

JavaScript 原生中默认是没有 Console 对象,这是宿主对象(也就是浏览器)提供的内置对象。 用于访问调试控制台, 在不同的浏览器里效果可能不同。

Console 对象常见的两个用途:
  • 显示网页代码运行时的错误信息。
  • 提供了一个命令行接口,用来与网页代码互动。

去掉的原因

  1. console.log 是辅助开发者调试代码的,在生产环境下不再需要输出。
  2. console.log 可能会造成内存泄漏,代码运行程序已结束,但因console.log输出需要在浏览器工具输出展示,造成内存不能回收。在Google Chrome浏览器已处理这种情况,但在其他浏览器可能就会存在内存泄漏。

next.js生产环境去掉console打印方法

在next.config.js中 nextjs-compiler 有讲解到:

nextjs-compiler: https://nextjs.org/docs/architecture/nextjs-compiler

//去掉所有console
module.exports = {
  compiler: {
    removeConsole: true,
  },
}
//除console.error(),其他都去掉
module.exports = {
  compiler: {
    removeConsole: {
      exclude: ['error'],
    },
  },
}
//因开发环境还需要用,只有生产环境才去掉console,调整如下
module.exports = {
   compiler: {
    // removeConsole: true,
    removeConsole:process.env.NODE_ENV === "production" ? { exclude: ["error",'info'] } : false,
  },
}
//这里修改一下,除了console.error()和console.info()其他的console都去掉
//然后将接口调用等地方的输出更换成console.error()和console.info()
  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

web16888

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值