標籤:屬性 設計 fbi 包含 class 停止 monit $$ dev
大家都有用過各種類型的瀏覽器,每種瀏覽器都有自己的特色,本人拙見,在我用過的瀏覽器當中,我是最喜歡Chrome的,因為它對於調試指令碼及前端設計調試都有它比其它瀏覽器有過之而無不及的地方。可能大家對console.log會有一定的瞭解,心裡難免會想調試的時候用alert不就行了,幹嘛還要用console.log這麼一長串的字串來替代alert輸出資訊呢,下面我就介紹一些調試的入門技巧,讓你愛上console.log
先的簡單介紹一下chrome的控制台,開啟chrome瀏覽器,按f12就可以輕鬆的開啟控制台
大家可以看到控制台裡面有一首詩還有其它資訊,如果想清空控制台,可以點擊左上方那個 來清空,當然也可以通過在控制台輸入console.clear()來實現清空控制台資訊。如所示
現在假設一個情境,如果一個數組裡面有成百上千的元素,但是你想知道每個元素具體的值,這時候想想如果你用alert那將是多慘的一件事情,因為alert阻斷線程運行,你不點擊alert框的確定按鈕下一個alert就不會出現。
下面我們用console.log來替換,感受一下它的魅力。
看了上面這張圖,是不是認識到log的強大之處了,下面我們來看看console裡面具體提供了哪些方法可以供我們平時調試時使用。
下面我們來一一介紹一下各個方法主要的用途。
一般情況下我們用來輸入資訊的方法主要是用到如下四個
1、console.log 用於輸出普通訊息
2、console.info 用於輸出提示性資訊
3、console.error 用於輸出錯誤資訊
4、console.warn 用於輸出警示資訊
用圖來說話
5、console.group 輸出一組資訊的開頭
6、console.groupEnd 結束一組輸出資訊
看你需求選擇不同的輸出方法來使用,如果上述四個方法再配合group和groupEnd方法來一起使用就可以輸入各種各樣的不同形式的輸出資訊。
哈哈,是不是覺得很神奇呀!
7、console.assert 對輸入的運算式進行斷言,只有運算式為false時,才輸出相應的資訊到控制台
8、console.count (這個方法非常實用哦)當你想統計代碼被執行的次數
9、console.dir (這個方法是我經常使用的 可不知道比for in方便了多少) 直接將該DOM結點以DOM樹的結構進行輸出,可以詳細查對象的方法發展等等
10、console.time 計時開始
11、console.timeEnd 計時結束(看了下面的圖你瞬間就感受到它的厲害了)
12、console.profile 和 console.profileEnd 配合一起使用來查看CPU使用相關資訊
在Profiles面板裡面查看就可以看到cpu相關使用資訊
13、console.timeLine 和 console.timeLineEnd 配合一起記錄一段時間軸
14、console.trace 堆疊追蹤相關的調試
上述方法只是我個人理解罷了。如果想查看具體API,可以上官方看看,具體地址為:https://developer.chrome.com/devtools/docs/console-api
下面介紹一下控制台的一些快速鍵
1、方向鍵盤的上下鍵 ,大家一用就知曉。比如用上鍵就相當於使用上次在控制台的輸入符號
2、$_ 命令返回最近一次運算式執行的結果,功能跟按向上的方向鍵再斷行符號是一樣的
上面的 $_ 需要領悟其奧義才能使用得當,而$0~$4則代表了最近5個你選擇過的DOM節點。
什麼意思?在頁面右擊選擇 審查元素 ,然後在彈出來的DOM結點樹上面隨便點選,這些被點過的節點會被記錄下來,而 $0 會返回最近一次點選的DOM結點,以此類推,$1返回的是上上次點選的DOM節點,最多儲存了5個,如果不夠5個,則返回 undefined 。
3、Chrome 控制台中原生支援類jQuery的選取器 ,也就是說你可以用 $ 加上熟悉的css選取器來選擇DOM節點
4、copy 通過此命令可以將在控制台擷取到的內容複寫到剪貼簿
(哈哈 剛剛從控制台複製的body裡面的html可以任意粘貼到哪 比如記事本 是不是覺得功能很強大)
5、keys和values 前者返回傳入對象所有屬性名稱組成的資料,後者返回所有屬性值組成的數組
說到這,不免想起 console.table 方法了
6、monitor & unmonitor
monitor(function),它接收一個函數名作為參數,比如 function a ,每次 a 被執行了,都會在控制台輸出一條資訊,裡麵包含了函數的名稱 a 及執行時所傳入的參數。
而unmonitor(function)便是用來停止這一監聽。
看了這張圖,應該明白了,也就是說在monitor和unmonitor中間的代碼,執行的時候會在控制台輸出一條資訊,裡麵包含了函數的名稱 a 及執行時所傳入的參數。當解除監視(也就是執行unmonitor時)就不再在控制台輸出資訊了。
$ // 簡單理解就是 document.querySelector 而已。$$ // 簡單理解就是 document.querySelectorAll 而已。$_ // 是上一個運算式的值,console對象#3.命令列API 裡有說明。$0-$4 // 是最近5個Elements面板選中的DOM元素,待會會講。dir // 其實就是 console.dirkeys // 取對象的鍵名, 返回鍵名組成的數組values // 去對象的值, 傳回值組成的數組
下面看一下console.log的一些技巧
1、重寫console.log 改變輸出文字的樣式
2、利用控制台輸出圖片
3、指定輸出文字的樣式
Chrome 控制台console的用法(學了之後對於調試js可是大大有用的哦)[轉]