日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

前言

Chrome瀏覽器我想是每一個前端er必用工具之一吧,一部分原因是它速度快,體積不大,支持的新特性也比其它瀏覽器多,還有一部分我想就是因為它的控制臺功能強大了吧,說它是神器一點也不過分,很方便。但其實很多開發者并沒有用出控制臺的精髓,只是使用簡單的console.log();其實控制臺功能遠遠不止這么簡單哦。

console.clear

console.clear();清空控制臺,這個應該和console.log知名度一樣高吧。

console.log家族

先簡單介紹一下chrome的控制臺,打開chrome瀏覽器,按f12就可以輕松的打開控制臺

 

Chrome 控制臺實用指南

 

 

如果你是一位開發者,我想console.log肯定是經常使用的了,我們主要看看console.log的幾個兄弟:

1.console.log ('普通信息')

2.console.info ('提示性信息')

3.console.error ('錯誤信息')

4.console.warn ('警示信息')

 

Chrome 控制臺實用指南

 

 

大家都會用log,但很少有人能夠很好地利用console.error,console.warn 等將輸出到控制臺的信息進行分類整理。他們功能區別不大,意義在于將輸出到控制臺的信息進行歸類,或者說讓它們更語義化。

如果再配合console.group 與console.groupEnd,可以將這種分類管理的思想發揮到極致。這適合于在開發一個規模很大模塊很多很復雜的Web App時,將各自的log信息分組到以各自命名空間為名稱的組里面。

console.group("app.bundle");console.warn("來自bundle模塊的警告信息1");console.warn("來自bundle模塊的警告信息2");console.groupEnd(); console.group("app.bundle");console.log("來自bundle模塊的信息1");console.log("來自bundle模塊的信息2");console.groupEnd();

 

Chrome 控制臺實用指南

 

 

這樣的控制臺信息看上去就一目了然了,就不用再為了找這是屬于那一行代碼輸出的再翻一遍源碼了。

另外,console.log家族還給我們提供了一個的API:第一個參數可以帶一些格式化指令,比如%c,n;看下面這個炫酷的效果:

console.log('%chello world', '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;');

 

Chrome 控制臺實用指南

 

 

當然,圖片也是可以的,讀者可以自行嘗試,修改上述代碼即可。

另外,console.log() 接收不定參數,參數間用逗號分隔,最終會輸出會將它們以空白字符連接。

 

Chrome 控制臺實用指南

 

 

console.table

看著這種“黑魔法”是不是有種坑分的感覺呢,其實還不止哦!console.table可以讓我們輸出表格,示例:

var data = {code:200,content:[{'品名': '杜雷斯', '數量': 4}, {'品名': '岡本', '數量': 3}]};console.table(data.content);

 

Chrome 控制臺實用指南

 

 

有的時候后端傳回來一大串數據,是不是覺得直接console.log或是通過抓包工具查看都會讓人暈頭轉向呢,這個時候正事console.table發揮作用的時候了,以表格的形式呈現數據,自然一目了然。

console.assert

var isDebug=false;console.assert(isDebug,'開發中的log信息。。。');

 

當你想代碼滿足某些條件時才輸出信息到控制臺,那么你大可不必寫if或者三元表達式來達到目的,cosole.assert便是這樣場景下一種很好的工具,它會先對傳入的表達式進行斷言,只有表達式為假時才輸出相應信息到控制臺。

 

Chrome 控制臺實用指南

 

 

console.count

除了條件輸出的場景,還有常見的場景是計數。

當你想統計某段代碼執行了多少次時也大可不必自己去寫相關邏輯,內置的console.count可以很地勝任這樣的任務.

 

Chrome 控制臺實用指南

 

 

console.dir

將DOM結點以JAVAScript對象的形式輸出到控制臺,而console.log是直接將該DOM結點以DOM樹的結構進行輸出,與在元素審查時看到的結構是一致的。不同的展現形式,同樣的優雅,各種體位任君選擇反正就是方便與體貼。

console.dir(document.body);console.log(document.body);

 

Chrome 控制臺實用指南

 

 

console.time & console.timeEnd

輸出一些調試信息是控制臺最常用的功能,當然,它的功能遠不止于此。當做一些性能測試時,同樣可以在這里很方便地進行。比如需要考量一段代碼執行的耗時情況時,可以用console.time與 console.timeEnd來做此事。

console.time("Array耗時");var arraynew Array(10000000);for (var i = array.length - 1; i >= 0; i--) { array[i] = new Object();};console.timeEnd("Array耗時");

 

Chrome 控制臺實用指南

 

 

當想要查看CPU使用相關的信息時,可以使用console.profile配合 console.profileEnd來完成這個需求。

這一功能可以通過UI界面來完成,Chrome 開發者工具里面有個tab便是Profile。使用方法和console.time基本一樣,其實time開發者工具里也有個tab就是timeline。關于console.prefile博主就不做多余的介紹了。想要做更多了解的讀者可以看這里。

$

講真,米國程序員們真的很喜歡money啊(誰又不是呢),看看php就知道了,滿屏的$。而在Chrome的控制臺里,$用處同樣是蠻多且方便的。

2+2//回車,再$_+1//回車得5

上面的$_需要領悟其奧義才能使用得當,而$0~$4則代表了最近5個你選擇過的DOM節點。

什么意思呢?在頁面右擊選擇審查元素,然后在彈出來的DOM結點樹上面隨便點選,這些被點過的節點會被記錄下來,而$0會返回最近一次點選的DOM結點,以此類推,$1返回的是上上次點選的DOM節點,最多保存了5個,如果不夠5個,則返回undefined。

 

Chrome 控制臺實用指南

 

 

另外值得一贊的是,Chrome 控制臺中原生支持類jQuery的選擇器,也就是說你可以用$加上熟悉的css選擇器來選擇DOM節點,多么滴熟悉。

$('body');$$('div');

 

Chrome 控制臺實用指南

 

 

$(selector)返回的是滿足選擇條件的首個DOM元素。

剝去她偽善的外衣,其實$(selector)是原生JavaScript document.querySelector() 的封裝。

同時另一個命令$$(selector)返回的是所有滿足選擇條件的元素的一個集合,是對document.querySelectorAll() 的封裝。

$x(path)

將所匹配的節點放在一個數組里返回

$x("//p");$x("//p[a]");

 

Chrome 控制臺實用指南

 

 

$x("//p")匹配所有的p節點,$x("//p[a]");匹配所有子節點包含a的p節點

copy

copy(document.body)

 

然后你就可以Ctrl+v了。

注意:他不依附于任何全局變量比如window,所以其實在JS代碼里是訪問不了這個copy方法的,所以從代碼層面來調用復制功能也就無從談起。但愿有天瀏覽器會提供相應的JS實現吧~這樣我們就可以通過js代碼進行復制操作而不用再依賴Flash插件了。

keys & values

這是一對基友。前者返回傳入對象所有屬性名組成的數據,后者返回所有屬性值組成的數組。具體請看下面的例子:

var tfboy={name:'wayou',gender:'unknown',hobby:'opposite to the gender'};keys(tfboy);values(tfboy);

 

Chrome 控制臺實用指南

 

 

monitor & unmonitor

monitor(function),它接收一個函數名作為參數,比如function a,每次a被執行了,都會在控制臺輸出一條信息,里面包含了函數的名稱a及執行時所傳入的參數。而unmonitor(function)便是用來停止這一監聽。

function sayHello(name){ alert('hello,'+name);}monitor(sayHello);sayHello('damonare');sayHello('tjz');unmonitor(sayHello);

 

 

Chrome 控制臺實用指南

 

 

 

debug & undebug

debug同樣也是接收一個函數名作為參數。當該函數執行時自動斷下來以供調試,類似于在該函數的入口處打了個斷點,可以通過debugger來做到,同時也可以通過在Chrome開發者工具里找到相應源碼然后手動打斷點。而undebug 則是解除該斷點。而其他還有好些命令則讓人沒有說的欲望,因為好些都可以通過Chrome開發者工具的UI界面來操作并且比用在控制臺輸入要方便。

 

Chrome 控制臺實用指南

 

 

原文鏈接:https://mp.weixin.qq.com/s/XagHDH_N2K9igi4jatB9Sw

分享到:
標簽:Chrome
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定