前端重写console.log方法

    xiaoxiao2022-07-06  174

    我们在开发前端的时候,有时候希望在开发和测试过程中,可以输出console.log日志,方便查看,但是在生产环境不需要再console.log的,于是想到重写console.log方法,以下有两种效果:

    1. 和原生console.log一样效果

    console.log = (function (oriLogFunc) { return function () { //判断配置文件是否开启日志调试 if (!Config.isProduct) { try{ oriLogFunc.call(console, ...arguments); }catch(e){ console.error('console.log error', e); } } } })(console.log);

    可以通过配置文件,决定是否要开启console.log输出。用法和原来一样,输出的效果和原生console.log一样,以下是输出结果图片:

     

    2. 以数组方式输出效果

    console.log = (function (oriLogFunc) { return function () { //判断配置文件是否开启日志调试 if (!Config.isProduct) { try{ if(arguments && arguments.length > 1){ let first = arguments[0]; let arr = Array.prototype.slice.call(arguments); let more = arr.slice(1); oriLogFunc.call(console, first, more); }else if (arguments && arguments.length == 1){ oriLogFunc.call(console, arguments[0]); } }catch(e){ console.error('console.log error', e); } } } })(console.log);

    可以通过配置文件,决定是否要开启console.log输出。用法和原来一样,以下是输出结果图片:

     

     

    两种方式都可以达到可配置console是否输出的效果,直接把代码放在程序最开始运行之前的位置就可以了。比如项目是RN,把这段代码放在src目录下的app.js文件运行;如果项目是小程序,把代码放在app.js的App()运行前面运行即可;如果项目是Vue,把代码放在main.js目录下运行即可。其它项目都可以类似的。

     

    按照上面方法,还可以重写console.error、console.debug方法。

    有疑问可以联系微信或QQ993301724

     

     

     

    最新回复(0)