The try ... catch statement allows you to test a block of code for errors.
When browsing Web pages on the internet, I guess we have all seen a JavaScript alert box, telling you there is a runtime error, and asking: "Do you wish to debug?" on some pages. Error message like that may be useful for developers, but not for the users. When users see errors, they often leave the Web page.
This chapter will teach you how to trap and handle JavaScript error messages, so you don't lose your audience.
There are two ways of catching errors in a Web page:
By using the try ... catch statement
By using the onerror event. This is the old standard solution to catch errors
The try ... catch statement allows you to test a block of code for errors. The try block contains the code to be run, and the catch block contains the code to be executed if an error occurs.
try |
Note that try ... catch is written in lowercase letters. Using uppercase letters will generate a JavaScript error!
The example below contains a script that is supposed to display the message "Welcome guest!" when you click on a button. However, there's a typo in the message() function. alert() is misspelled as adddlert(). A JavaScript error occurs:
<html> |
To take more appropriate action when an error occurs, you can add a try ... catch statement.
The example below contains the "Welcome guest!" example rewritten to use the try ... catch statement. Since alert() is misspelled, a JavaScript error occurs. However, this time, the catch block catches the error and executes a custom code to handle it. The code displays a custom error message informing the user what happened:
<html> |
The next example uses a confirm box to display a custom message telling users they can click OK to continue viewing the page or click Cancel to go to the homepage. If the confirm method returns false, the user clicked Cancel, and the code redirects the user. If the confirm method returns true, the code does nothing:
<html> |
The onerror event will be explained soon, but first you will learn how to use the throw statement to create an exception. The throw statement can be used together with the try ... catch statement.
To see how HTML and JavaScript work, you can only push the submit button, or you can make your own HTML and JavaScript code.