日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

分享一个自定义的 console 类,让你不再纠结JS中的调试代码的兼容

發布時間:2023/11/29 javascript 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 分享一个自定义的 console 类,让你不再纠结JS中的调试代码的兼容 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

問題的產生

  在寫JS的過程中,為了調試我們常常會寫很多 console.log、console.info、console.group、console.warn、console.error代碼來查看JS的運行情況,但發布時又因為IE不支持console,又要去掉這些代碼,一不小心就會出錯。

  本文分享自己昨晚寫的一個console類來試圖解決這一問題。當然,更好的做法是把測試代碼分開寫,那樣就不會有這個問題。

解決思路

  如何解決IE下不兼容的問題呢,那就是我們自己定義一個console類來覆蓋瀏覽器提供的console功能,這樣只要在頁面中引用此JS文件就可以了。

  另外,此類還提供了查看輸出的調試信息功能,console 定義了哪些功能呢,我們可以在這里看到:http://getfirebug.com/wiki/index.php/Console_API,我們可以看到這里提供了很多方法,我們常用的有?console.log、console.info、console.group、console.warn、console.error、console.profile、console.time,最后兩個是分析代碼性能的,比較復雜,本文沒有實現。

代碼解析

  第一步,當然是搭一個結構,覆蓋瀏覽器(firebug、chrome)提供的console功能,這樣直接引用此JS文件即可保證瀏覽器(主要是IE)中不出錯:

console var console={ assert:function(){ }, clear:function(){ }, count:function(){ }, debug:function(){ }, dir:function(){ }, dirxml:function(){ }, error:function(){ }, exception:function(){ }, group:function(name){ }, groupCollapsed:function(){ }, groupEnd:function(){ }, info:function(){ }, log:function(){ }, memoryProfile:function(){ }, memoryProfileEnd:function(){ }, profile:function(){ }, profileEnd:function(){ }, table:function(){ }, time:function(){ }, timeEnd:function(){ }, timeStamp:function(){ }, trace:function(){ }, warn:function(){ } };

  第二步,實現 console.log方法。在所實現的幾個方法中這個是最復雜的。

  從firebug的API中我們可以看到,console.log不僅僅可以輸出信息,還提供了類似 string.Format的功能,直接引用原文如下:

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

PatternType
?%sString
?%d,?%iInteger (numeric formatting is not yet supported)
?%fFloating point number (numeric formatting is not yet supported)
?%oObject hyperlink
?%cStyle 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<args.length;i++){if(/%s|%d|%i|%o/.test(args[0])){args[0]=args[0].replace(/%s|%d|%i|%o/,args[i]);}else{break;}}if(i<args.length){args[0]=args[0]+" "+args.slice(i).join(" ");}if(hasstyle){consoleHelper.showlog(args[0],args[1]);}else{consoleHelper.showlog(args[0]);}}else if(args.length==1){if(arguments[0] instanceof Array){consoleHelper.showlog("["+args[0]+"]");}else if(arguments[0] instanceof Function){consoleHelper.showlog(args[0],null,"console_log_function");}else{consoleHelper.showlog(args[0]);}}else{consoleHelper.showlog("");}

  由于console.log可以接受多個參數,且個數不確定,所以這里直接沒有寫形參。對于%c雖然firebug中寫在中間也是有效的,這里為了簡單直接只對寫在開頭的有效。代碼中先把參數轉換為數組,然后對數組進行分情況處理。

  當參數個數大于1時,對后面的參數用replace進行替換,然后把剩下的參數連接(join)起來進行輸出。

  當參數個數為1時,還要分兩種情況,一是數組,二是方法。對于數組,按firebug中的格式,在兩端加中括號,對于函數,把字的顏色變為綠色

  當參數個數為0時,直接輸出空字符串

  后面的consoleHelper.showlog是為了輸出方便另外寫的一個方法,在這個方法中把各種調試信息的結果顯示在頁面上的一個div(如果存在)中。

  其他幾個方法的思路跟這個差不多,只是樣式不同,功能比這個簡單,直接把參數連接起來輸出即可。

  整個console類代碼如下:

console全部代碼 var console={ assert:function(){ }, clear:function(){ }, count:function(){ }, debug:function(){ }, dir:function(){ }, dirxml:function(){ }, error:function(){var args=Array.prototype.slice.call(arguments);consoleHelper.showerror(args.join(" ")); }, exception:function(){ }, group:function(name){consoleHelper.showgroup(name); }, groupCollapsed:function(){ }, groupEnd:function(){ }, info:function(){var args=Array.prototype.slice.call(arguments);if(args.length==1){if(arguments[0] instanceof Array){consoleHelper.showinfo("["+args[0]+"]");}else if(arguments[0] instanceof Function){consoleHelper.showinfo(args[0],"console_log_function");}else{consoleHelper.showinfo(args[0]);}}else{consoleHelper.showinfo(args.join(" "));} }, log:function(){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<args.length;i++){if(/%s|%d|%i|%o/.test(args[0])){args[0]=args[0].replace(/%s|%d|%i|%o/,args[i]);}else{break;}}if(i<args.length){args[0]=args[0]+" "+args.slice(i).join(" ");}if(hasstyle){consoleHelper.showlog(args[0],args[1]);}else{consoleHelper.showlog(args[0]);}}else if(args.length==1){if(arguments[0] instanceof Array){consoleHelper.showlog("["+args[0]+"]");}else if(arguments[0] instanceof Function){consoleHelper.showlog(args[0],null,"console_log_function");}else{consoleHelper.showlog(args[0]);}}else{consoleHelper.showlog("");} }, memoryProfile:function(){ }, memoryProfileEnd:function(){ }, profile:function(){ }, profileEnd:function(){ }, table:function(){ }, time:function(){ }, timeEnd:function(){ }, timeStamp:function(){ }, trace:function(){ }, warn:function(){var args=Array.prototype.slice.call(arguments);if(args.length==1){if(arguments[0] instanceof Array){consoleHelper.showwarn("["+args[0]+"]");}else if(arguments[0] instanceof Function){consoleHelper.showwarn(args[0],"console_log_function");}else{consoleHelper.showwarn(args[0]);}}else{consoleHelper.showwarn(args.join(" "));} } };

  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("<div style="+style+">");}}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一方面是工作中有這方面的需求,另外也是因為在博問中看到有人問?JavaScript中如何獲得console.log的值??,前段時間有個國外學編程網站可以把console.log的結果直接顯示在頁面上,不知道是不是用了本文類似的方案。

  歡迎大家留言討論。

總結

以上是生活随笔為你收集整理的分享一个自定义的 console 类,让你不再纠结JS中的调试代码的兼容的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。