Vanilla JavaScript try...catch

β€” 4 minute read

permalink

JavaScript errors are one of the worse, in my opinion, their vague, reference a million files and do not always make perfect sense.

This is where the try...catch can come in handy.

Let's dive into Try , Catch and Finally

Simple try catch in Vanilla JavaScript permalink

The most easy way that I tend to use is the following:

try {
// Insert your code here
} catch (e) {
// e now contains your error
}

Doesn't solve or block anything, but defines your error better.

Try Catch Finally permalink

There is another block we can add to our try...catch and it's called finally this code will always be executed no matter what the try or catch do, see following example:

try {
throw new Error('Error made');
} catch (e) {
console.error(e.message);
} finally {
console.log('All done');
}
// Output:
// Error made
// All done

JavaScript throw permalink

As you can see in above example we actually use throw but what does that even mean?

We use the throw to send custom errors

Handling specific Errors in try catch permalink

Sometimes it's just not enough to console log the whole error, but let's say it's a specific type of error we want to return something else. For this use case we can use instanceof.

try {
doSomethingBad();
} catch (e) {
if (e instanceof TypeError) {
// statements to handle TypeError exceptions
} else if (e instanceof RangeError) {
// statements to handle RangeError exceptions
} else if (e instanceof EvalError) {
// statements to handle EvalError exceptions
} else {
// statements to handle any unspecified exceptions
consoel.log(e); // Just log the error
}
}

Mix try...catch with promises permalink

I tend to use try...catch a lot in promise scenarios. It's an super easy way to reject the code without it crashing.

See the following example:

function getAPIBaseURL() {
return new Promise(function(resolve, reject) {
try {
// Call api do function code
resolve(returnData);
} catch (error) {
reject(error);
}
});
}

As your can see we use a promise as normal, but inside we include a try...catch block and resolve if the try function returns correct else we reject with the error.

See it in action on this Codepen:

Thank you for reading, and let's connect! permalink

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter