博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
分享一个自定义的 console 类,让你不再纠结JS中的调试代码的兼容
阅读量:5862 次
发布时间:2019-06-19

本文共 8803 字,大约阅读时间需要 29 分钟。

问题的产生

  在写JS的过程中,为了调试我们常常会写很多 console.log、console.info、console.group、console.warn、console.error代码来查看JS的运行情况,但发布时又因为IE不支持console,又要去掉这些代码,一不小心就会出错。

  本文分享自己昨晚写的一个console类来试图解决这一问题。当然,更好的做法是把测试代码分开写,那样就不会有这个问题。

解决思路

  如何解决IE下不兼容的问题呢,那就是我们自己定义一个console类来覆盖浏览器提供的console功能,这样只要在页面中引用此JS文件就可以了。

  另外,此类还提供了查看输出的调试信息功能,console 定义了哪些功能呢,我们可以在这里看到:,我们可以看到这里提供了很多方法,我们常用的有 console.log、console.info、console.group、console.warn、console.error、console.profile、console.time,最后两个是分析代码性能的,比较复杂,本文没有实现。

代码解析

  第一步,当然是搭一个结构,覆盖浏览器(firebug、chrome)提供的console功能,这样直接引用此JS文件即可保证浏览器(主要是IE)中不出错:

console

  第二步,实现 console.log方法。在所实现的几个方法中这个是最复杂的。

  从firebug的API中我们可以看到,console.log不仅仅可以输出信息,还提供了类似 string.Format的功能,直接引用原文如下:

  Here is the complete set of patterns that you may use for string substitution:

Pattern Type
 %s String
 %d, %i Integer (numeric formatting is not yet supported)
 %f Floating point number (numeric formatting is not yet supported)
 %o Object hyperlink
 %c Style formatting

 

  其中的%c比较特殊,是给输出添加样式的,比如我们在firebug中这样写:

console.log('%cTest output', 'color:white; background-color:blue');

  运行后的结果是这样的:

  这里%c也可以跟 %s、%d等混用。

  所以,在代码中我直接用replace进行替换,由于JS中的replace默认只替换第一个匹配项,这里刚好,代码如下:

var args=Array.prototype.slice.call(arguments);    if(args.length>1){        var i=1,hasstyle=false;        if(args[0].indexOf("%c")==0){            args[0]=args[0].replace(/%c/,"");            i=2;            hasstyle=true;        }        for(;i

  由于console.log可以接受多个参数,且个数不确定,所以这里直接没有写形参。对于%c虽然firebug中写在中间也是有效的,这里为了简单直接只对写在开头的有效。代码中先把参数转换为数组,然后对数组进行分情况处理。

  当参数个数大于1时,对后面的参数用replace进行替换,然后把剩下的参数连接(join)起来进行输出。

  当参数个数为1时,还要分两种情况,一是数组,二是方法。对于数组,按firebug中的格式,在两端加中括号,对于函数,把字的颜色变为绿色

  当参数个数为0时,直接输出空字符串

  后面的consoleHelper.showlog是为了输出方便另外写的一个方法,在这个方法中把各种调试信息的结果显示在页面上的一个div(如果存在)中。

  其他几个方法的思路跟这个差不多,只是样式不同,功能比这个简单,直接把参数连接起来输出即可。

  整个console类代码如下:

console全部代码

  consoleHelper代码如下:

var consoleHelper={showlog:function(val,style,cla){    if(cla){        cla="console_log "+cla;    }    else{        cla="console_log";    }    this.show(val,style,cla);},showinfo:function(val,cla){    if(cla){        cla="console_info "+cla;    }    else{        cla="console_info";    }    this.show(val,null,cla);},            showwarn:function(val,cla){    if(cla){        cla="console_warn "+cla;    }    else{        cla="console_warn";    }    this.show(val,null,cla);},showerror:function(val){    this.show(val,null,"console_error");},showgroup:function(val){    if(!val){        val="";    }    this.show(val+":",null,"console_group");},show:function(val,style,cla){    if(document.getElementById("showconsole")){        var div=document.createElement("div");        if(div.setAttribute){            if(style){                div.setAttribute("style",style);            }        }        else{            if(style){                div=document.createElement("
"); } } if(cla){ div.className=cla; } var oText=document.createTextNode(val); div.appendChild(oText); document.getElementById("showconsole").appendChild(div); }}};

  注:如果想在页面中看到调试信息,直接在页面上添加一个id 为 showconsole 的隐藏的div即可。

  样式(尽量跟FireBug保持一致):

.console_log{
border:1px solid #CCC; color:#333; padding:0px 5px; min-height:24px; line-height:24px; margin-bottom:-1px;}.console_info{
border:1px solid #CCC; color:#333; padding:0px 5px; min-height:24px; line-height:24px; margin-bottom:-1px; background: url("") no-repeat scroll 0 1px #EBF5FF; padding-left:30px;}.console_warn{
border:1px solid #CCC; color:#333; padding:0px 5px; min-height:24px; line-height:24px; margin-bottom:-1px; background: url("") no-repeat scroll 0 1px #FFFFC8; padding-left:30px;}.console_error{
border:1px solid #CCC; color:#FF0000; padding:0px 5px; min-height:24px; line-height:24px; margin-bottom:-1px; background: url("") no-repeat scroll 0 1px #FFEBEB; padding-left:30px;}.console_group{
margin-top:20px; font-size:16px; font-weight:bolder;}.console_log_function{
color:green;}

  这里为了演示方便,三个小图标直接用的是base64格式的图片,就是上面代码中的三个长字符串,大家用时可以换成图片地址。

小结

  写这个JS一方面是工作中有这方面的需求,另外也是因为在博问中看到有人问  ,前段时间有个国外学编程网站可以把console.log的结果直接显示在页面上,不知道是不是用了本文类似的方案。

  欢迎大家留言讨论。

本文转自博客园博客,原文链接:,如需转载请自行联系原作者

你可能感兴趣的文章
(cons '(〇 . 前言) 《为自己写本-Guile-书》)
查看>>
监控软件zabbix之安装
查看>>
No architectures to compile for (ONLY_ACTIVE_ARCH=YES, active arch=arm64, VALID_ARCHS=armv7 armv7s)
查看>>
Exchange Server 2016 独立部署/共存部署 (七)—— DAG功能测试
查看>>
Linq==数据访问层?
查看>>
对RTMP视频流进行BitmapData.draw()出错的解决办法
查看>>
Linux 进程中 Stop, Park, Freeze【转】
查看>>
Vertica的这些事<十>—— vertica中group by 和join 语句的优化
查看>>
Spark修炼之道(基础篇)——Linux大数据开发基础:第九节:Shell编程入门(一)...
查看>>
MySQL中如何启用InnoDB数据引擎
查看>>
Duplicate Symbol链接错误的原因总结和解决方法[转]
查看>>
适配器模式
查看>>
刨根问底区块链 —— 基础篇
查看>>
swift GCD 的一些高级用法
查看>>
php 直接调用svn命令
查看>>
建立低权限的ftp帐号
查看>>
htpasswd
查看>>
Android窗口机制(三)Window和WindowManager的创建与Activity
查看>>
Android 编译出错解决
查看>>
iOS--The request was denied by service delegate (SBMainWorkspace) for reason:
查看>>