這篇文章為大家帶來了關於javascript中的相關知識,其中主要介紹了JavaScript的調試技巧,包括了Sources面板、設定斷點等相關問題,希望對大家有幫助。
相關推薦:javascript影片教學
#作為前端開發,我們會經常使用console.log() 來調試程序中的問題。雖然這種方式也能解決一部分問題,但是它的效率不如能執行逐步除錯的工具。本文就來學習如何使用 Google Chrome developer tools 輕鬆除錯 JavaScript 程式碼。
多數瀏覽器都提供了DevTools 供我們調試JavaScript 應用程序,並且它們的使用方式類似,只要我們學會瞭如何在一個瀏覽器上使用調試工具,就很容易在其他瀏覽器上使用它。
以下就以Greet Me 程式為例,這個程式非常簡單,只要輸入名字和願望,最後會輸出一句話:
當輸入兩個表單值之後,「願望」部分沒有正確列印,而是印出了NaN。程式碼線上偵錯:https://greet-me-debugging.vercel.app/。接下來,就來看看 Chrome DevTools 有什麼功能可以偵錯定位程式碼的問題。
DevTools 提供了許多不同的工具供我們進行調試,包括 DOM 檢查、分析和網路呼叫檢查等。這裡要說的是 Sources 面板,它可以幫助我們調試 JavaScript。可以使用快速鍵 F12 開啟控制台,並點選 Sources 標籤以導覽至 Sources 面板,也可以直接使用快速鍵 Command Option I(Mac)或 Control Shift I(Windows、Linux)來開啟。
Sources 面板主要由三個部分組成:
檔案導航區:頁面請求的所有檔案都會在此列出;
程式碼編輯區:當我們從檔案導覽列中選取一個檔案時,該檔案的內容就會在此列出,我們可以在這裡編輯程式碼;
Debugger區:這裡會有很多工具可以用來設定斷點,檢查變數值、觀察執行步驟等。
如果DevTools 視窗較寬或未在單獨的視窗中打開,則偵錯器部分將顯示在程式碼編輯器的右側:
要開始偵錯程式碼,首先要做的就是設定斷點,斷點就是程式碼執行暫停以便偵錯它的邏輯點。
DevTools 允許我們以不同的方式來設定斷點:
#在程式碼行;
#
當print()方法中的name變數值為Joe時,程式碼的執行就會暫停。需要注意,只有我們確定調試的程式碼的大致範圍時,才會使用條件斷點。
在事件監聽器上設定斷點的步驟:
點選切換到Sources選項卡;
在debugger區域展開Event Listener Breakpoints選項;
從事件清單中選擇事件監聽器來設定斷點。我們的程式中有一個按鈕點擊事件,這裡就選擇 Mouse 事件選項中的click。
提示:當我們想要暫停在事件觸發後執行的事件偵聽器程式碼時可以使用此選項。
DevTools 在 DOM 檢查和偵錯方面同樣強大。當在 DOM 中新增、刪除或修改某些內容時,可以設定斷點來暫停程式碼的執行。
在DOM 上設定斷點的步驟:
點擊切換到Elements 標籤;
找到要設定斷點的元素;
右鍵點選元素以獲得上下文選單,選擇Break on選項,然後選擇Subtree modifications、Attribute modifications、Node removal中的一個即可:
這三個選項的意義如下:
#Subtree modifications:當節點內部子節點變化時斷點;
Attribute modifications:當節點屬性變更時斷點;
Node removal:當節點移除時斷點。
如上圖,我們在輸出訊息的 p 的 DOM 發生變化時設定了一個斷點。當點擊按鈕後,問候訊息輸出到 p 中,子節點的內容髮生了變化,就會發生中斷。
注意: 當我們懷疑是DOM更改導致了錯誤時,就可以使用該選項,當 DOM 更改中斷時,相關的 JavaScript 程式碼執行將自動暫停。
現在我們知道了設定斷點的方式。在複雜的調試情況下,我們可能需要使用這些調試的組合。調試器提供了五個控制項來逐步執行程式碼:
下面就分別來看看這些控制都是如何使用的。
此選項使我們能夠在JavaScript程式碼執行時逐行執行,如果中途有函數調用,單步執行也會進入函數內部,逐行執行,然後退出。
此選項允許我們在執行程式碼時跳過一些程式碼。有時我們可能已經確定某些功能是正常的,不想花時間去檢查它們,就可以使用跳過選項。
下面就是單步執行logger()函數時,會跳過函數的執行:
使用該選項可以更深入地了解函數。單步執行函數時,當感覺某個函數的行為異常並想檢查它時,就可以使用這個選項來進入函數內部並進行偵錯。
下面就是單步執行logger() 函數:
在單步執行一個函數時,我們可能不想再繼續執行並退出它,就可以使用這些選項退出函數。
下面就是進入了logger() 函數內部,然後立即退出:
有時,我們希望從一個斷點跳到另一個斷點,而無需在它們之間進行任何調試,就可以使用這個選項來跳到下一個斷點:
當進行逐行偵錯時,檢查變數的範圍和值以及函數呼叫的呼叫堆疊。在Debugger區可以這三個選項:
可以在Scope 選項中查看局部範圍和全域範圍內的內容以及變量,也可以看到this 的即時指向:
呼叫堆疊面板有助於識別函數執行堆疊:
檢查程式碼中的值是識別程式碼中錯誤的主要方法。在單步執行時,我們只需要將滑鼠懸停在變數上即可檢查值。
下面可以看到變數name 在程式碼執行時的檢查值:
#此外,我們可以選擇打碼的一部分作為表達式來檢查值。在下面的範例中,選擇了表達式document.getElementById('m_wish') 來檢查值:
注意,上述方法不會刪除斷點,只會在暫時停用它們。要再次啟動這些斷點,只需再點一次這個斷點即可。
透過取消選取的複選框,可以從「Breakpoints」面板中刪除一個或多個斷點。透過右鍵點選並選擇「刪除所有斷點」選項,可以刪除所有斷點: #六、使用VS Code 偵錯JavaScriptVisual Studio code 中一些實用的插件可以用於JavaScript 程式碼的調試。可以安裝一個名為“Debugger for Chrome”的插件來調試程式碼: #安裝之後,點擊左側的run 選項並建立配置以運行/偵錯JavaScript 應用程式. 這樣就會建立一個名為launch.json 的文件,其中包含一些設定資訊:{ "version": "0.2.0", "configurations": [ { "type": "chrome", "request": "launch", "name": "Debug the Greet Me app", "url": "<http://localhost:5500>", "webRoot": "${workspaceFolder}" } ] }
最后,回到最开始的问题,这里不再一步步调试,通过上述的调试方法判定,只需要在 wish 变量前面加一个 + 即可:
const message = 'Hello ' + name + ', Your wish `' + + wish + '` may come true!';
相关推荐:javascript学习教程
以上是超實用的JavaScript調試技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!