最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

Do uncatchable exceptions exist in Javascript? - Stack Overflow

programmeradmin2浏览0评论

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
Add a comment  | 

3 Answers 3

Reset to default 19

If 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.

发布评论

评论列表(0)

  1. 暂无评论