Chrome DevTools debugging reference
Set a breakpoint using DevTools
Open the Chrome DevTools (Cmd + Shift + I
).
Go the Sources tab and locate a JavaScript file.
Click on a line number. The line number should become highlighted in blue.
Reload the page and Chrome will halt execution when it reaches your breakpoint.
data:image/s3,"s3://crabby-images/806a8/806a89a5380fecd9867f3e947f1667d1d87731cf" alt="How to set breakpoins in Chrome DevTools"
Similar approach should work for other browsers.
Set a breakpoint using the debugger
statement
You can insert the debugger statement anywhere in your source code and Chrome DevTools (or any available debugger in the current JavaScript environment) will break just before that line. DevTools must be open for the breakpoint to be triggered.
For example, if you load a script in Chrome with the following JavaScript code:
console.log('hey')
debugger;
console.log('hello')
And you open the DevTools and reload the page, Chrome will halt execution at line two.
Set conditional breakpoints
Set a breakpoint at any line.
Right click the breakpoint (works in Chrome and Jetbrains IDEs) and click Edit breakpoint.
Enter a condition / expression that must evaluate to true
for the breakpoint to be triggered.
data:image/s3,"s3://crabby-images/3b720/3b72017d4824afc9006f4455f9fb08ac568799e2" alt="Condition breakpoints in Chrome DevTools."
Set DOM breakpoints
DOM breakpoints can be used to set breakpoints on:
- Attribute modifications: find out what code is changing an attribute (e.g., class, id,
data-*
, etc). - Subtree modifications: find out what code is changing nodes within the element.
- Node removal: find out what code is removing a node.
To set DOM breakpoints, right-click on an element in the Elements tab and select a breakpoint trigger:
data:image/s3,"s3://crabby-images/18c99/18c9909efc05b3581db32260f87499f46e286bfa" alt="Set DOM breakpoints."
Set event listener breakpoints
Event listener breakpoints halt execution whenever a particular event fires (e.g., click, keypress
, readystatechange
, setInterval,
etc).
data:image/s3,"s3://crabby-images/1ff77/1ff7701342fe1a300a1e0e62720faa2191f73036" alt="Event Listener breakpoints."
Pause on any JavaScript code
Halt execution as soon as any JavaScript is executed.
data:image/s3,"s3://crabby-images/0857b/0857ba4af86c428b4f8798199fafb54aa2937597" alt="Pause on any JavaScript code."
Pause on uncaught exceptions
data:image/s3,"s3://crabby-images/f226c/f226c3b9c4188f9a4001207896217ddaf2b5ceef" alt="Pause on uncaught JavaScript exceptions."
Pause on all exceptions
data:image/s3,"s3://crabby-images/05985/05985c332154541325cac6b989b05a9a3a554c83" alt="Pause on all JavaScript exceptions."
Watch the values of variables / expressions
You can add variables or expressions (e.g., typeof myVar
, foo.bar
, someFunction()
) to a watch list and then watch the value change as you step through your code. This is useful when you’re trying to figure out how a variable’s value changes as your code is executed.
data:image/s3,"s3://crabby-images/a215f/a215f3359fd8b529b4d891bdc52b4fade445af00" alt="Watch the value of variables and expressions in Chrome DevTools."
Step through code
Step over next function call
Step over the next function call without pausing inside any nested functions.
Step into next function call
Step into the next function call and recursively into any nested functions.
Step out of current function
Step out of the current function. Useful when you want to step back up the call stack.
Open interactive console at any breakpoint
Press Esc
to open the interactive console at any breakpoint. You will have access to the scope of the current breakpoint.
data:image/s3,"s3://crabby-images/8e051/8e05120731d37034936f477d1140bc25b380c4f7" alt="Open Chrome DevTools' interactive console at any breakpoint"
Add scripts to ignore list
You can tell Chrome DevTools to ignore / black-box certain scripts when stepping through code. This is useful when you’re confident that a bug doesn’t lie in a certain third-party library (e.g., jQuery) and so you don’t want the debugger to step through its code.
To black box a script, open up the script in the Sources panel, right-click anywhere inside the file, and choose Add script to ignore list.
data:image/s3,"s3://crabby-images/b7e8e/b7e8e7ed86b9a845675c0b03a493b6d0e59c1d34" alt="Ignore scripts in the Chrome DevTools debugger"
After you’ve black-boxed a script, its frames won’t show up in the call stack. Instead, you’ll see a Show ignore-listed frames button:
data:image/s3,"s3://crabby-images/677b4/677b435f5179e85cbfc1f6525bb80862470abd69" alt="Black-boxed scripts don't show up in the call stack."
Other notes
- What is a debugger?
- Execution pauses just before your breakpoint.
- You can toggle breakpoints to enable / disable them individually. You can also enable / disable all breakpoints.
Thanks for your comment 🙏. Once it's approved, it will appear here.
Leave a comment