Do any javascript runtimes (browsers, Node, etc.) ever throw uncatchable exceptions? Are any and all exceptions ever encountered in a javascript environment catchable in a try/catch statement?
Do any javascript runtimes (browsers, Node, etc.) ever throw uncatchable exceptions? Are any and all exceptions ever encountered in a javascript environment catchable in a try/catch statement?
Share Improve this question asked Dec 8, 2014 at 11:51 Magnus WolffeltMagnus Wolffelt 4821 gold badge3 silver badges11 bronze badges 4- 1 Sharing your research helps everyone. Tell us what you've tried and why it didn’t meet your needs. This demonstrates that you’ve taken the time to try to help yourself, it saves us from reiterating obvious answers, and most of all it helps you get a more specific and relevant answer. Also see How to Ask – gnat Commented Dec 8, 2014 at 11:56
- Exceptions from asynchronous callbacks are hard (but not impossible) to catch. Basically it depends on the environment that provides the async functionality. – Bergi Commented Dec 8, 2014 at 16:40
- Does this question belong to programmers.se ? – dynamic Commented Dec 8, 2014 at 17:00
- There are silent security errors that are not catchable, because catching them would reveal information about the system hardware. It would be difficult to argue if these were actually Javascript errors or not. – Reactgular Commented Dec 8, 2014 at 22:30
3 Answers
Reset to default 19If by exceptions you mean any exceptional condition that breaks your script, then all of them can throw uncatchable exceptions, since most syntax errors aren't catchable. Only syntax errors from dynamically evaluated code (eval
, new Function
) can be caught.
try { :( } catch(e) { } // uncatchable syntax error
That's assuming you mean catchable using try..catch
. Technically you could use the error
event to trap syntax errors from other script blocks:
<script> onerror = function (e) { return true; }; </script>
<script> :( </script>
On the other hand, maybe you don't consider errors that happen before evaluation to be exceptions. In that case "uncatchable exceptions" may be relegated to exceptions throws from other execution contexts (such as a function invoked with setTimeout), where you don't have control over the execution context throwing the exception. Of course, these exceptions will not disrupt the flow of your program.
Some errors are really uncatchable (at least at the time of writing this post). Try to put this in Google Chrome's console:
try {
var elm = document.createElementNS("http://www.w3.org/2000/svg", "text");
elm.setAttribute("transform", "translate(106.7 NaN)");
} catch (e) {
console.log('caught:', e);
}
We expect to see "caught:"
and then an error data, but instead you'll see this right away:
`Error: <text> attribute transform: Expected ')', "translate(106.7 NaN)".`
To generalize the other answer - exceptions that are asynchronous are generally are impossible to handle without the "bug guns" designed especially to handle them - that is domains and the process "uncaughtException"
event in node and onerror
in the browser.
The simplest way to get such an error would be:
setTimeout(function(){
throw "Catch me if you can!";
});
This is what you're seeing in the http.get({host:host, port:80}, console.error);
in the example of the other answer.