Sources面板用於資源檢索、代碼邏輯調試。html
其餘篇章有的是以掘金爲示例演示的,而掘金是服務端渲染(SSR),資源壓縮,不易演示。git
以ElementUI官網爲示例講述:
github
經過連接打開頁面,經過F12或鼠標右鍵【檢查】打開開發者工具控制檯。chrome
資源管理器面板segmentfault
代碼編輯面板跨域
代碼Debugger面板瀏覽器
該面板下的功能牢牢依賴着資源管理面板、代碼編輯面板、調試面板。網絡
只不過細分到下層面板管理不一樣的資源:dom
Page面板
Filesystem面板
Snippets面板
咱們以Page面板爲主體講述,其它小面板(Filesystem、Snippets)一帶而過。
默認佈局的1位置即Page面板的所有內容,該面板列出了當前站點頁面執行的全部資源,咱們能夠經過該面板獲取如下站點信息:
技術棧:
相關資源:
依賴域:
瀏覽器擴展程序
爲了乾淨的調試環境,排除擴展程序的干擾,因此,通常選用無痕模式調試
在Page面板中點擊任意資源,便可在默認佈局2的編輯面板中看到資源詳情。
上圖點擊了圖片資源,能夠看到該圖片是一張二維碼。
上圖點擊了CSS資源,在默認佈局2位置的編輯面板中,能夠點擊左下角的 {} 按鈕,進行代碼美化 —— 根據當前CSS資源的大小,美化所須要的時間不一樣。
若資源太大,瀏覽器可能會由於CPU佔用太高卡死。
這裏咱們作了一個試驗,檢索到頂部菜單的選擇器,進行樣式更新,能夠實時地在頁面上看到展現效果,甚至不須要保存。
然而,在這裏修改的代碼只是保存在內存中,刷新頁面代碼就還原了。
這裏,咱們將Javascript資源單獨講述,由於在Devtools中JS資源調試的複雜度較高。
以修復Bug爲例:
Note:針對網絡請求,斷點時間過長會形成請求超時。
說到調試代碼,經常使用的方式有兩種:斷點、日誌;
斷點Debugger | 日誌Console |
---|---|
中斷代碼的執行 | 不中斷代碼的執行 |
查看中斷代碼那一時刻的上下文信息 | 查看代碼執行結束的上下文信息 |
非侵入式 | 侵入式,將日誌代碼寫入業務代碼中 |
查看代碼中斷時刻全部的執行上下文信息 | 只能查看指定的打印信息 |
時效性:此時此刻的值 | 代碼執行結束時指定信息的值,除非深拷貝 |
在代碼編輯面板中,只有針對Javascript的斷點才能攔截執行成功,而針對DOM的斷點,須要在Elements面板添加:DOM的操做,詳情參見Elements篇。
下述以Chrome瀏覽器提供的官方調試代碼爲例:
打開控制檯,從Panel面板中能夠看到當前頁面只有兩個資源:HTML頁面及相關的JavaScript。
其它的是我安裝的Chrome擴展(沒有使用無痕模式)。
從get-started.html中咱們能夠看到相關的HTML結構、Style樣式及引入的JavaScript代碼。
輸入Number一、Number2,點擊按鈕得到計算結果。
計算獲取Number一、Number2兩個數字的和:1 + 1 = 2
獲取到Number一、Number2字符串的拼接:1 + 1 = 11
100%,說明是邏輯錯誤,而不是代碼邏輯對某種邊界沒有覆蓋的機率問題。
function updateLabel() { var addend1 = getNumber1(); var addend2 = getNumber2(); var sum = addend1 + addend2; label.textContent = addend1 + ' + ' + addend2 + ' = ' + sum; }
由代碼 label.textContent = addend1 + ' + ' + addend2 + ' = ' + sum;
及 1 + 1 = 11
的顯示結果猜想,addend1
、addend2
看似沒有問題,而sum
看似有問題,那咱們就在sum
計算的地方打斷點。
在資源管理器中點擊html引入的Javascript文件,找到相關代碼,在行號位置點擊一下,即添加斷點,再次點擊同一行號,取消斷點。
點擊按鈕,觸發函數調用,此時,咱們能夠看到當前執行上下文中的全部信息,如addend1
、addend2
的值,偷偷的執行F9(Step),能夠看到sum
的結果。
從當前執行上下文能夠看到addend1
、addend2
的值是字符串類型,而字符串作加法就是字符串的拼接,因此,結果沒問題!!!
是的,運算結果沒問題,那爲何不是咱們指望的結果呢?
由於咱們指望的是數字類型相加!!!
聚焦控制檯,經過ESC按鍵能夠在當前面板開啓/隱藏Console面板,在控制檯的最下方。
藉助斷點將做用域限制在函數updateLabel
內,經過Console面板驗證本身的猜測,此時,Console面板能夠訪問函數updateLabel
的變量。
那咱們只要將addend1
、addend2
的值轉換爲數字便可。
方案有不少種:
parseInt()
parseFloat()
Number()
1 * '1'
這裏,我直接在代碼編輯器面板中改動了getNumber1
、getNumber2
的方法,另其返回數字類型的數據。
保存之後,點擊按鈕,能夠看到指望的結果。
經過右上角按鈕,切換斷點的激活狀態,激活是深藍色,取消激活是有透明度的藍色。
取消激活狀態下,斷點不會攔截代碼的執行。
在取消激活的狀態下,能夠嘗試輸入不一樣的值,檢測邏輯的正確性。
簡單的調試示例到此結束。
JavaScript調試 | CSS調試 |
---|---|
須要保存 | 無需保存 |
須要手動執行調用,不會自動執行 | 自動執行,實時效果 |
可斷點攔截執行 | 斷點無效 |
上述調試Javascript的前提是要熟悉代碼,比較適用於在本身編寫的程序中調試。
若遇到其它的場景,如第三方庫調試,則須要根據相應的場景,選擇合適的斷點組合使用。
斷點類型 | 應用場景 |
---|---|
代碼行斷點 | 大致/清晰知道調試範圍時使用 |
代碼行條件斷點 | 大致/清晰知道調試範圍時,且只調試某指定條件分支下使用 |
代碼行日誌斷點 | 非代碼侵入式的打印日誌 |
DOM斷點 | 調試指定DOM的改變、移除或子節點的變更,詳見Elements篇 |
XHR斷點 | 調試URL包含指定字符串的請求 |
事件監聽斷點 | 調試指定元素事件觸發邏輯時使用事件委託時使用比較麻煩推薦配合黑盒 + 無痕模式使用 |
錯誤斷點 | 調試錯誤捕獲時使用通常只用於調試未捕獲的錯誤 |
經過問題復現能推測出明確的調試代碼範圍時使用。
在代碼編輯面板的行號上右鍵或者直接點擊該行號,便可添加代碼行斷點。
在有中介統籌分配處理邏輯或條件分支時使用,排除其它邏輯的干擾,聚焦關注點。
由上圖可知,在代碼編輯面板的行號上右鍵,選擇Add Conditional Breakpoint...,便可添加代碼行條件斷點。
添加條件斷點時,若是條件爲true時,攔截代碼執行,條件爲false時,不會攔截。
在輸入框至少有一個爲空時,斷點有效,輸入框全不爲空時,斷點無效。
無需侵入源代碼,實現非侵入式的日誌打印
如上圖,輸入的格式是console.log函數的參數形式。
如上圖,能夠顯式地使用console對象的其它方法打印日誌
詳情參見Elements篇
隨手找個請求,添加到XHR斷點,重載頁面,在請求send的時候,會攔截代碼邏輯,能夠查看相關的請求參數。
若對代碼不熟悉或在大長篇代碼邏輯中,只是知道點擊觸發業務處理邏輯時,能夠考慮事件監聽器斷點。
然而,在複雜的事件委託中,是一個噩夢。
Note:無痕模式下使用,瀏覽器擴展程序會產生干擾。
開啓錯誤斷點,默認會攔截未處理的錯誤邏輯。
若選擇Pause on caught exceptions
,則捕獲的錯誤邏輯也會被攔截。
黑盒(舊版叫黑盒,新版瀏覽器更名爲忽略列表)是一小功能,單獨拉出來說是由於不適合和其它分類合併。
使用該功能能夠聚焦關注點,排除非核心或可信任代碼的干擾。
由於示例是一個很簡單地例子,這裏藉助Event Listener Breakpoints
講述該功能地使用。
在Click事件上添加斷點,點擊Add Number1 and Number2
按鈕,會在函數onClick
地首行進行執行攔截,OK!
重載頁面,在代碼編輯面板打開可信任的代碼,右鍵添加Add script to ignore list
,再次點擊Add Number1 and Number2
按鈕,會發現代碼邏輯徹底執行結束,沒有攔截。
上述場景對比,咱們能夠意識到,黑盒幫助咱們聚焦相關邏輯代碼,跳過一些可信任(認爲不會出現Bug)的庫,如:jQuery?
在一步步調試時,不會進入jQuery
庫調試,聚焦咱們本身的邏輯。
能夠幫助咱們查找無效(Never)代碼。
經過代碼編輯面板右下角的Coverage
,咱們能夠查看代碼的覆蓋率。
如上圖,頁面初始化執行時,代碼未覆蓋率爲41.9%,即有41.9%的代碼在頁面初始化時未執行。
點擊Add Number1 and Number2
按鈕,執行了輸入校驗相關的代碼邏輯,代碼未覆蓋率爲17.3%,即仍有17.3%的代碼未執行。
輸入輸入,點擊Add Number1 and Number2
按鈕,執行了計算相關的代碼邏輯,代碼未覆蓋率爲0%,即代碼邏輯所有執行。
某種程度上能夠幫助咱們查找Never無效代碼。
在調試代碼的過程當中,咱們須要控制代碼的執行:
如上圖,添加三個斷點,追加一個日誌。
觸發事件,點擊Resume script execution
,會恢復代碼的執行,直至遇到下一個斷點。
若在攔截時,長按Resume script execution
,選擇下拉按鈕的第一項,會跳事後續的斷點,將代碼執行完整,能夠看到日誌執行了一次。
若在攔截時,長按Resume script execution
,選擇下拉按鈕的第二項,會在攔截處強制中止後續代碼執行,能夠看到後續邏輯中的日誌沒有執行。
重載頁面,使頁面恢復到初始狀態。
調試面板最上排的工具控制斷點攔截時代碼的執行,Resume
按鈕恢復代碼的執行,直至遇到下一個斷點。
若斷點所在代碼行的表達式是一個函數,step over
按鈕會跳過函數的內部執行,如圖第15行(15L),下一步直接執行到了16L。
若斷點所在代碼行的表達式是一個函數,step into
按鈕會深刻函數的內部執行,如圖第15行(15L),下一步進入了函數內部,執行到了22L。
執行到了22L後,若不想再調試該函數inputsAreEmpty
,能夠經過step out
跳出函數的執行,以下圖,下一步直接跳出當前函數的執行,執行到16L。
思考:
Step into
按鈕,下一步會執行到哪?Step through
按鈕,下一步會執行到哪?
最後看一下step
按鈕,step
按鈕是實名的老實人,遇山登山,遇海潛海,邏輯中的每一步都會走到,碰見函數就會深刻函數代碼執行每一步。
若邏輯中一個函數都沒有,step over
、step into
、step out
、step
的行爲和step
保持一致。
看下圖,分別執行了禁用、停用,看明白了麼?
上圖,加入了兩種類型的斷點,第一次正常執行,三個斷點都會執行的到。
第二次禁用了斷點,點擊Add Number1 and Number2
,代碼執行完畢,斷點都沒有攔截。
第三次激活斷點(還原禁用),停用了斷點,點擊Add Number1 and Number2
,代碼攔截在了Click事件處理邏輯的首行,後續斷點並無攔截。
迷糊了?
綜述:
停用是有做用域的,停用的只是代碼行斷點,其它類型的斷點並無停用。而禁用是所有類型的斷點都不會觸發。
重載頁面,移除全部的斷點。
能夠增長表達式在Watch中,監聽執行各時間點的值。
函數調用的監聽會影響代碼邏輯的執行,如上圖中的 inputsAreEmpty()
做爲Watch表達式,Watch在須要更新展現的時候(時機:代碼執行到表達式所在所用域),Chrome會自動調用該函數來獲取函數最新返回值。
若是在 inputsAreEmpty()
的函數邏輯中添加斷點,就會無限循環。
在 inputsAreEmpty()
代碼行處添加代碼行斷點,函數體會執行三次
inputsAreEmpty()
自己執行inputsAreEmpty()
執行後,更新Watch表達式的值inputsAreEmpty()
函數體內無斷點,更新Watch表達式後,再也沒有其它時機更新表達式在 inputsAreEmpty()
函數體內添加代碼行斷點,函數體無限執行
inputsAreEmpty()
在執行做用域初始化inputsAreEmpty()
inputsAreEmpty()
後,更新WatchinputsAreEmpty()
inputsAreEmpty()
後,更新Watch因此,不推薦在Watch表達式中添加函數調用。
在攔截代碼執行時,咱們能夠在調試面板的Scope章節看到當前做用域Local的變量,如上圖中的this。
繼續執行代碼到return 語句,能夠在當前做用域Local看到返回值Return Value
雙擊做用域中的值,能夠改變當前的值。
Global做用域能夠看到全局做用域的變量、方法。
默認狀態下,Console面板只能訪問到全局的變量、函數,而在斷點攔截時,Console面板能夠訪問到當前做用域下的方法、變量。
調用棧Call Stack,能夠看到當前執行函數的來源,幫助咱們溯源。
在當前執行函數上右鍵,點擊 restart frame,可讓當前函數的邏輯從新執行,在大塊代碼段調試中使用較爲便利,僅限於斷點執行到的函數,已經走過的函數無效。
瀏覽器即代碼編輯器
如上圖,在本地啓動服務打開某靜態頁面,在Sources面板下的Filesystem面板添加靜態項目到workspaces。
經過Elements面板定位錨點到某DOM節點,在Styles面板直接調試樣式,重載頁面後,該樣式依舊有效。
經過查看樣式源碼,能夠發現Styles面板中調試的樣式已經保存到磁盤覆蓋原有的樣式。
靜態頁面的CSS、JavaScript
上圖咱們能夠看到Filesystem中的一些文件的文件名有綠色小點
靜態頁面的HTML經過Elements面板右鍵 eidt HTML 沒法保存磁盤
【推薦】在結構、展示、動效(HTML、CSS、JavaScript)分離的靜態頁面項目中快速調試使用。
使用構建工具打包的項目
Snippets面板爲咱們提供跨標籤、跨域名的Javascript測試性功能。
上圖附了一段檢測瀏覽器類型的Javascript腳本, Ctrl + S 保存後,能夠打開其它頁籤,在Snippets面板中仍然能看到該腳本。
點擊右下角的執行按鈕或經過快捷鍵 Ctrl + Enter 執行這段腳本,能夠在下方的Control面板看到執行打印出來的日誌。
Snippets | Console |
---|---|
跨標籤頁可用 | 當前標籤頁可用 |
永久保存,除非手動刪除 | 頁面重載後清除 |