欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

除Console.log()外更多的Javascript調(diào)試命令

 更新時(shí)間:2018年01月24日 09:43:43   作者:徐大大  
本篇文章給大家介紹了除Console.log()外更多的Javascript調(diào)試命令,方便大家更多環(huán)境下的JS調(diào)試,學(xué)習(xí)下吧。

Console 對(duì)象提供對(duì)瀏覽器控制臺(tái)的接入(如:Firefox 的 Web Console)。不同瀏覽器上它的工作方式是不一樣的,但這里會(huì)介紹一些大都會(huì)提供的接口特性。

Console對(duì)象可以在任何全局對(duì)象中訪問,如 Window,WorkerGlobalScope 以及通過屬性工作臺(tái)提供的特殊定義。
它被瀏覽器定義為 Window.Console,也可被簡(jiǎn)單的 Console 調(diào)用。

最常用的方法就是Console.log(),就是在控制臺(tái)輸出內(nèi)容。剛開始學(xué)前端的時(shí)候看到大家都是用的Console.log(),幾乎沒有見過Console的其他用法,難道Console真的沒有別的用法了?查了一下后發(fā)現(xiàn)Console還是非常強(qiáng)大的,至于為什么很少看到有人用可能是因?yàn)橛眠^都刪掉了吧。在此記錄一下Console的其他用法。

注意:因?yàn)镃onsole 對(duì)象提供對(duì)瀏覽器控制臺(tái)的接入 所以在不同瀏覽器中的支持及表現(xiàn)形式可能不太一樣,但是調(diào)試內(nèi)容只有我們開發(fā)者會(huì)看,所以保證開發(fā)環(huán)境能用這些方法就可以了,下面演示全部都為Chrome上面的效果。

分類輸出

不同類別信息的輸出

console.log('文字信息');
console.info('提示信息');
console.warn('警告信息');
console.error('錯(cuò)誤信息');

分組輸出

使用Console.group()Console.groupEnd()包裹分組內(nèi)容。

還可以使用Console.groupCollapsed()來代替Console.group()生成折疊的分組。

console.group('第一個(gè)組');
 console.log("1-1");
 console.log("1-2");
 console.log("1-3");
console.groupEnd();
console.group('第二個(gè)組');
 console.log("2-1");
 console.log("2-2");
 console.log("2-3");
console.groupEnd();

Console.group()還可以嵌套使用

console.group('第一個(gè)組');
 console.group("1-1");
  console.group("1-1-1");
   console.log('內(nèi)容');
  console.groupEnd();
 console.groupEnd();
 console.group("1-2");
  console.log('內(nèi)容');
  console.log('內(nèi)容');
  console.log('內(nèi)容');
 console.groupEnd();
console.groupEnd();
console.groupCollapsed('第二個(gè)組');
 console.group("2-1");
 console.groupEnd();
 console.group("2-2");
 console.groupEnd();
console.groupEnd();

表格輸出

使用console.table()可以將傳入的對(duì)象,或數(shù)組以表格形式輸出。適合排列整齊的元素

var Obj = {
 Obj1: {
  a: "aaa",
  b: "bbb",
  c: "ccc"
 },
 Obj2: {
  a: "aaa",
  b: "bbb",
  c: "ccc"
 },
 Obj3: {
  a: "aaa",
  b: "bbb",
  c: "ccc"
 },
 Obj4: {
  a: "aaa",
  b: "bbb",
  c: "ccc"
 }
}
console.table(Obj);
var Arr = [
 ["aa","bb","cc"],
 ["dd","ee","ff"],
 ["gg","hh","ii"],
]
console.table(Arr);

查看對(duì)象

使用Console.dir()顯示一個(gè)對(duì)象的所有屬性和方法
在Chrome中Console.dir()Console.log()效果相同

var CodeDeer = {
 nema: 'CodeDeer',
 blog: 'www.xluos.com',
  
}
console.log("console.dir(CodeDeer)");
console.dir(CodeDeer);
console.log("console.log(CodeDeer)");
console.log(CodeDeer);

查看節(jié)點(diǎn)

使用Console.dirxml()顯示一個(gè)對(duì)象的所有屬性和方法

在Chrome中Console.dirxml()Console.log()效果相同

百度首頁logo的節(jié)點(diǎn)信息

條件輸出

利用console.assert(),可以進(jìn)行條件輸出。

當(dāng)?shù)谝粋€(gè)參數(shù)或返回值為真時(shí),不輸出內(nèi)容當(dāng)?shù)谝粋€(gè)參數(shù)或返回值為假時(shí),輸出后面的內(nèi)容并拋出異常

console.assert(true, "你永遠(yuǎn)看不見我");
console.assert((function() { return true;})(), "你永遠(yuǎn)看不見我");
console.assert(false, "你看得見我");
console.assert((function() { return false;})(), "你看得見我");

計(jì)次輸出

使用Console.count()輸出內(nèi)容和被調(diào)用的次數(shù)

(function () {
 for(var i = 0; i < 3; i++){
  console.count("運(yùn)行次數(shù):");
 }
})()

追蹤調(diào)用堆棧

使用Console.trace()來追蹤函數(shù)被調(diào)用的過程,在復(fù)雜項(xiàng)目時(shí)調(diào)用過程非常多,用這個(gè)命令來幫你縷清。

function add(a, b) {
 console.trace("Add function");
 return a + b;
}
function add3(a, b) {
 return add2(a, b);
}
function add2(a, b) {
 return add1(a, b);
}
function add1(a, b) {
 return add(a, b);
}
var x = add3(1, 1);

計(jì)時(shí)功能

使用Console.time()Console.timeEnd()包裹需要計(jì)時(shí)的代碼片段,輸出運(yùn)行這段代碼的事件。

Console.time()中的參數(shù)作為計(jì)時(shí)器的標(biāo)識(shí),具有唯一性。 Console.timeEnd()中的參數(shù)來結(jié)束此標(biāo)識(shí)的計(jì)時(shí)器,并以毫秒為單位返回運(yùn)行時(shí)間。最多同時(shí)運(yùn)行10000個(gè)計(jì)時(shí)器。

console.time("Chrome中循環(huán)1000次的時(shí)間");
for(var i = 0; i < 1000; i++)
{
}
console.timeEnd("Chrome中循環(huán)1000次的時(shí)間");

性能分析

使用Console.profile()Console.profile()進(jìn)行性能分析,查看代碼各部分運(yùn)行消耗的時(shí)間,但是我在Chrome自帶的調(diào)試工具中并沒有找到在哪里查看這兩個(gè)方法生成的分析報(bào)告。應(yīng)該需要其他的調(diào)試工具。

有趣的Console.log()

最后再來介紹一下強(qiáng)大的Console.log(),這個(gè)方法有很多的用法(其他輸出方法的用法,如error()等,可以參照log()使用)。

一、提示輸出

可以再輸出的對(duì)象、變量前加上提示信息,增加辨識(shí)度

var ans = 12345;
console.log("這是臨時(shí)變量ans的值:",ans);

二、格式化輸出

占位符 含義 %s 字符串輸出 %d or %i 整數(shù)輸出 %f 浮點(diǎn)數(shù)輸出 %o 打印javascript對(duì)象,可以是整數(shù)、字符串以及JSON數(shù)據(jù)

樣例:

var arr = ["小明", "小紅"];
console.log("歡迎%s和%s兩位新同學(xué)",arr[0],arr[1]);
console.log("圓周率整數(shù)部分:%d,帶上小數(shù)是:%f",3.1415,3.1415);

三、自定義樣式

使用%c為打印內(nèi)容定義樣式,再輸出信息前加上%c,后面寫上標(biāo)準(zhǔn)的css樣式,就可以為輸出的信息添加樣式了

console.log("%cMy stylish message", "color: red; font-style: italic");
console.log("%c3D Text", " text-shadow: 0 1px 0 #ccc,0 2px 0 #c9c9c9,0 3px 0 #bbb,0 4px 0 #b9b9b9,0 5px 0 #aaa,0 6px 1px rgba(0,0,0,.1),0 0 5px rgba(0,0,0,.1),0 1px 3px rgba(0,0,0,.3),0 3px 5px rgba(0,0,0,.2),0 5px 10px rgba(0,0,0,.25),0 10px 10px rgba(0,0,0,.2),0 20px 20px rgba(0,0,0,.15);font-size:5em");
console.log('%cRainbow Text ', 'background-image:-webkit-gradient( linear, left top, right top, color-stop(0, #f22), color-stop(0.15, #f2f), color-stop(0.3, #22f), color-stop(0.45, #2ff), color-stop(0.6, #2f2),color-stop(0.75, #2f2), color-stop(0.9, #ff2), color-stop(1, #f22) );color:transparent;-webkit-background-clip: text;font-size:5em;');
console.log('%cMy name is classicemi.', 'color: #fff; background: #f40; font-size: 24px;');

總結(jié)

Console的用法很多,有些再調(diào)試過程中非常實(shí)用,可以節(jié)省很多時(shí)間。當(dāng)然我知道debug還是用斷點(diǎn)調(diào)試的方法比較好,但是小問題用“printf大法”也是很好用的(滑稽臉)。

相關(guān)文章

  • 基于JavaScript簡(jiǎn)單實(shí)現(xiàn)一下新手引導(dǎo)效果

    基于JavaScript簡(jiǎn)單實(shí)現(xiàn)一下新手引導(dǎo)效果

    這篇文章主要為大家詳細(xì)介紹了如何基于JavaScript簡(jiǎn)單實(shí)現(xiàn)一下新手引導(dǎo)效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-03-03
  • 一文讓你快速了解JavaScript棧

    一文讓你快速了解JavaScript棧

    這篇文章主要介紹了一文讓你快速了解JavaScript棧,棧全稱為堆棧,是一種先進(jìn)后出的的數(shù)據(jù)結(jié)構(gòu),棧中只有兩種基本操作,也就是插入和刪除,也就是入棧和出棧操作,棧只有一端可以進(jìn)行入棧和出棧操作,我們將其稱為棧頂,另一端稱其為棧底
    2022-07-07
  • JS async 函數(shù)的含義和用法實(shí)例總結(jié)

    JS async 函數(shù)的含義和用法實(shí)例總結(jié)

    這篇文章主要介紹了JS async 函數(shù)的含義和用法,結(jié)合實(shí)例形式總結(jié)分析了JS async 函數(shù)的基本功能、含義、使用方法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-04-04
  • 微信js-sdk界面操作接口用法示例

    微信js-sdk界面操作接口用法示例

    這篇文章主要介紹了微信js-sdk界面操作接口用法,結(jié)合實(shí)例形式分析了微信界面操作的相關(guān)接口功能與使用技巧,需要的朋友可以參考下
    2016-10-10
  • JS控制GIF圖片的停止與顯示

    JS控制GIF圖片的停止與顯示

    這篇文章主要為大家詳細(xì)介紹了JS控制GIF圖片的停止與顯示,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(三):鏈表

    JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(三):鏈表

    這篇文章主要介紹了JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(三):鏈表,本文分別講解了單鏈表與雙鏈表以及增加節(jié)和刪除節(jié)的代碼實(shí)例,需要的朋友可以參考下
    2015-06-06
  • JavaScript如何將偽數(shù)組轉(zhuǎn)換成數(shù)組?

    JavaScript如何將偽數(shù)組轉(zhuǎn)換成數(shù)組?

    這篇文章主要介紹了JavaScript如何將偽數(shù)組轉(zhuǎn)換成數(shù)組,?偽數(shù)組的主要特征是一個(gè)對(duì)象,并且該對(duì)象有l(wèi)ength屬性,更多參考內(nèi)容,需要的小伙伴可以參考一下
    2022-07-07
  • 前端導(dǎo)出word文件的多種方式以及導(dǎo)出excel文件

    前端導(dǎo)出word文件的多種方式以及導(dǎo)出excel文件

    導(dǎo)出功能是項(xiàng)目開發(fā)中經(jīng)常會(huì)遇到的需求,在此就前端方面需要做的部分做一個(gè)總結(jié),這篇文章主要給大家介紹了關(guān)于前端導(dǎo)出word文件的多種方式以及導(dǎo)出excel文件的相關(guān)資料,需要的朋友可以參考下
    2024-08-08
  • JavaScript實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘效果

    JavaScript實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘效果

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)動(dòng)態(tài)時(shí)鐘效果,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下,希望對(duì)你的學(xué)習(xí)有所幫助
    2022-06-06
  • Bootstrap入門書籍之(三)柵格系統(tǒng)

    Bootstrap入門書籍之(三)柵格系統(tǒng)

    這篇文章主要介紹了Bootstrap入門書籍之(三)柵格系統(tǒng)的相關(guān)資料,需要的朋友可以參考下
    2016-02-02

最新評(píng)論