Debugging Javascript - Console and Debugger
Table of Contents
We have recently had some interns start at UNiDAYS and while showing how to write Jest tests in our solution one thing they started doing is adding console.log
to various places in the code to see how it worked.
- Open Chrome
- Press F12
This will show you the Chrome Dev Tools debugger.
We will be playing in Console and Sources tabs. For now, select the Console tab.
For those already familiar with the below, check out the Chrome API Reference. It has all sorts of cool things like console.assert
, console.count
and console.time
!
console.log
This is standard, you maybe use this all the time to print out messages or objects to see what value is at the time of it being called. This is a slow way of debugging but still a viable option.
You can do this by adding
console.log(‘Code be here’);
Or
console.log(myObject);
This will print the message to the console window.
console.warn and console.error
This is just like console.log, however you can get a nicely coloured error or warning message into your console. This can have advantages for debugging errors and warnings in a debug/local environment or if you are building a 3rd party plugin of some sort, a far better way of displaying that something is wrong in the way they have implemented your code rather than just throwing an error.
console.table
Used like console.log but it will instead display your object in the console as a table view. If you are wanting to log out an array or complex object, try this first, it is infinitely better to be able to see the data rather than console.log
.
console.table(jsonObject);
debugger
When you need to debug and step through your code, adding this to your JavaScript will prompt Chrome Dev Tools to pause and open up the Sources tab. From here you have full access to the stack and can step through your code to find your issue or better understand the flow of you code.
debugger;
Console sidebar
Now you have console.warn
, console.error
, console.log
and console.table
all printing data to your console, it can become hard to sift through all the noise.
Click on the icon like above and this will open up a sidebar to allow you to filter what type of message you want to see.
You also have the ability to filter your messages using the filter bar. Again this is a massive time saver when searching for specific messages registered to your console window.