An understanding of errors is absolutely vital to the task of coding. Absolutely everyone, including a first-day beginner to a PhD at NASA, makes mistakes constantly. You can get better, graduate from one kind of error to another, but making things will always be a sort of trial-and-error.
Not understanding errors means that your programs “work” or “don’t work”, and in-between is a feeling of helplessness and hours spent guessing. This is a waste. There’s information available that says what sorts of problems exist and where they come from - all you need to do is understand it.
Diagnosing errors is also a vital skill for using other people’s code: it’ll help you report better bugs and point to the cause faster.
There are two main types of errors: compile errors and runtime errors.1
", then it will simply give up on running any part of the program and report its confusion.
Runtime errors, on the other hand, happen sometime while your code is running. This could be almost immediately, like in the case of a
ReferenceError, or it could happen 5 minutes after someone has been using a website, when some bad data mucks everything up.
All right: let’s meet the errors.
SyntaxError is potentially the most commonly seen error for newcomers. Some common cases in which you’ll see it crop up are:
', but not the closing
As the example above demonstrates,
SyntaxErrors are often flagged by the syntax highlighting in your editor: if you type
var break = 1; in Sublime, you’ll notice that
break is red, the color of a keyword, rather than the color of a variable.
SyntaxErrors are usually compile-time errors: even though this example has the code
console.log('running') above the error, that never runs, and you never see
running in your console. The SyntaxError shuts it all down before a single line of code is run.
There are two big cases where SyntaxErrors are not compile-time:
Both of these errors can happen at any time: you use AJAX to get some data and it’s invalid, and you’ll get a SyntaxError.
ReferenceError means “the variable you referenced does not exist”. A few popular common ways this crops up are:
TypeError crops up when you accidentally mistake one kind of variable for another. This crops up when:
toUpperCase) on the type you gave it.
There’s also another case where you might run into errors if you roll with the no-semicolon crowd:
var y = x together with the immediately-invoked function below it, and sees
x is a number, not a function, hence the error. The message is illustrative of another fact: the line & snippet given is where the error starts, not necessarily the full context of why it happened. In this case you need to read both lines to see the problem.
RangeError is thrown when you give errors that are outside of the logical realm: for instance, here I’m trying to create an
length = -1. Like the physical world, there is nothing less than emptiness.
But given that most of the time you should use the
Array constructor and the other places this crops up, like
Number.toPrecision, aren’t super used, this is the minority of places you’ll see it. Most of the time you’ll see this case:
Maximum call stack size exceeded message telling you that your recursion is out of control.
For the sake of compleness, we’ll mention URIError, but it’s really not very common.
encodeURIComponent(). Not every URI is valid - sometimes you’ll have a case like this one, where the percent character is only valid with two hexademical digits after it to serve as percent encoding. And if you give one of these invalid inputs to the URI-eating functions, they’ll reject it roundly with this error.
Knowing the basic types of errors should get you started on the path to seeing those cryptic messages as helpful hints. In the next episode, I’ll discuss the most important parts of Google Chrome that you don’t use yet, the call stack, breakpoints, and more. Feel free to hit me up at @tmcw with questions or comments.
I’ve compiled examples of each error type in a GitHub repository: clone it and run them in node, or copy them and run them in your developer console to try them out.