gpt4 book ai didi

google-chrome - 如何使用 Chrome DevTools 在 AngularJS 异常中暂停脚本执行?

转载 作者:行者123 更新时间:2023-12-05 01:20:56 25 4
gpt4 key购买 nike

我知道 AngularJS 默认捕获所有应用程序异常,然后将它们记录到控制台。这使得 Chrome 中的“暂停未捕获的异常”按钮(我经常使用)毫无用处。

很多时候我在我的代码中遇到小的 javascript 错误(比如访问 undefined variable 的成员),我真的习惯于暂停异常并检查情况。

我现在唯一的解决方案是在触发错误的代码上放置一个断点(不切实际)或使用“暂停所有异常”按钮,但我必须继续处理 jQuery 默认生成的所有错误, Angular 和其他框架,这也很讨厌。

我还尝试覆盖 $exceptionHandler 服务,并在其中放置一个断点,但我无法从生成错误的函数中的调用堆栈访问。

那么,是否可以在 AngularJS 应用程序中使用“暂停未捕获的异常”?

最佳答案

根据 Angular 文档,

https://docs.angularjs.org/api/ng/service/ $异常处理程序

This example will override the normal action of $exceptionHandler, to make angular exceptions fail hard when they happen, instead of just logging to the console.


angular.module('exceptionOverride', []).factory('$exceptionHandler', function() {
return function(exception, cause) {
exception.message += ' (caused by "' + cause + '")';
throw exception;
};
});

这将导致它们由浏览器开发工具处理,这将允许暂停捕获的异常、使用源映射来获得良好的堆栈跟踪等。

大概您不希望在生产中发生这种情况,也不希望在开发过程中不断添加/删除此代码。我们通过在开发过程中添加并覆盖我们的生产代码的“开发”模块来解决这个次要问题。例如:

在 dev.html 中:


...

在 dev.js 中:

angular.module('devApp', ['mainApp'])
.factory('$exceptionHandler', ...)

关于google-chrome - 如何使用 Chrome DevTools 在 AngularJS 异常中暂停脚本执行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19973865/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com