使用Raygun来自动追踪AngularJS中的异常  更新时间:2015年06月23日 09:22:51   投稿:goldensun   这篇文章主要介绍了使用Raygun来自动追踪AngularJS中的异常,AngularJS是一款高人气的JavaScript库,需要的朋友可以参考下 Angular.js取得的巨大成就之一是实用的异常抛出,因为异常信息经常能够准确的表明你的代码为什么崩溃了。运行于世界各地的众多浏览器的大型客户端web应用会面临异常丢失的问题,而捕获它就有可能修复 bug并赢得用户。 当处理跨浏览器和设备的问题时,接收这些异常信息是很重要的,因为你的应用可能在你的开发机器上运行得正确可靠,但在你的用户的浏览器上却是另一番场景。 其解决方案是需要一个自动异常跟踪服务,而Raygun通过接收你的Angular web应用抛出的所有异常但不需要你做任何事,从而简化了这项工作。它的设置真的很快--只需要按照以下步骤将Raygun hook到你的应用就可以了。 安装 首先,下载小巧的Raygun4JS脚本,并把它添加到你的项目中。有3个途径获得: 通过Bower   复制代码 代码如下: bower install raygun4js 从NuGet获得——在Visual Studio中,打开包管理器控制台然后输入:   复制代码 代码如下: Install-Package raygun4js 手动下载 – 点击此处下载dev版 或者压缩过的版本 配置 接下来,引用这个脚本。如果你使用静态的HTML,将添加到页面里面或添加到你的模块加载器中。 最后,在你的Angular主逻辑执行之前调用下面的代码来设置Raygun4JS:   Raygun.init(‘YOUR_API_KEY’).attach(); 你可以为每一个用Raygun创建的app生成一个API key,你可以在你的Raygun dashboard 中访问他——你有30天免费试用时间来测试它。 在Angular中捕获异常 至少有两种方法将未处理的异常注射到Angular.js的模块中,通过使用decorator 或 factory。这两种方式会为你提供$exceptionHandler的具体实现,我们上面所提到的Raygun4JS会将该实现发送给Raygun。 使用一个装饰器 装饰器模式因其不会覆盖掉原有的行为,所以很适合用来将行为注入到任意的服务中,以确保在其它所期望的特性中分离关注点,它也是记录日志和处理异常的理想方式. 在Angular.js中它可以使用在 $provide 服务中,我们将用来实现我们自己的 $exceptionHandler 函数: app.config(function ($provide) { $provide.decorator(“$exceptionHandler”, [‘$delegate’, function($delegate) { return function (exception, cause) { Raygun.send(exception); $delegate(exception, cause); } }]) }); $delegate 是异常处理器的实体,我们会调用它来获得输出到控制台的原始行为. 你也可以按照自己的需要创建足够多的其它服务:   $provide.decorator(“$exceptionHandler”, [‘$delegate’, ‘$log’, function($delegate, $log) { return function (exception, cause) { $log.debug(‘Sending to Raygun’); Raygun.send(exception); $delegate(exception, cause); } }]) 依赖于所获取到的自Angular逻辑中抛出的错误是什么类型, cause 参数得以被填充. 如果一个异常发生在一个工厂或者服务中,你可能会得到那个参数可以的范围, 你可以将其作为自定义数据,通过替换掉上面的Raygun.send调用,附带任何你需要的其它东西,再传送到Raygun:   Raygun.send(exception, { cause: cause }); 使用一个工厂 快速的将Raygun放到你的应用的异常处理器中的方法就是使用一个工厂, 尽管它会移除原来的控制台日志,而如果你想要保留此项功能的话,就会需要存储原来的值并再一次调用它.   app.factory(‘$exceptionHandler’, function () { return function (exception) { Raygun.send(exception); } }); 手动发送错误 Raygun4JS 也归于了你任意时间很容易的手动跟踪错误的能力:   Raygun.send(new Error(‘my custom error’)); 供应器上还有一堆其它使用的工具可以利用,包括独特的用户跟踪,版本跟踪,标签及其它 – 这里的文档可以查看 的所有相信信息. Raygun 甚至可以在你的Angular应用中跟踪jQuery 的Ajax错误even tracks jQuery Ajax errors ,而无需你的做任何额外的事情, 因此你将得到开箱即用的全面照顾. 准备好使用Raygun了吗? 如之前所提及的,有一个 30天免费的无信用卡支付的版本可用, 因此你可以获取一个来看看你的应用是否真的是在为你的用户运作的. 如果就本文你有任何的疑问,请将它们留在下面的评论中。 您可能感兴趣的文章: JS异步堆栈追踪之为什么await胜过Promise Java动态追踪技术探究之从JSP到Arthas JS/HTML5游戏常用算法之追踪算法实例详解 详解VueJS 数据驱动和依赖追踪分析 JavaScript错误处理和堆栈追踪详解 JS脚本实现网页自动秒杀点击 基于JS脚本语言的基础语法详解 js脚本编写简单刷票投票系统 如何用JS追踪用户 AngularJS 异常 相关文章 对Angular中单向数据流的深入理解 这篇文章主要给大家介绍了关于对Angular中单向数据流的深入理解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。 2018-03-03 AngularJS入门教程二:在路由中传递参数的方法分析 这篇文章主要介绍了AngularJS在路由中传递参数的方法,结合实例形式分析了AngularJS实现路由中传递参数的相关技巧,并总结了相关操作步骤与注意事项,需要的朋友可以参考下 2017-05-05 AngularJS入门教程中SQL实例详解 本文主要介绍 AngularJS SQL,这里给大家整理了相关资料,并提供了实例代码,有需要的小伙伴可以参考下 2016-07-07 详解angularjs popup-table 弹出框表格指令 本篇文章主要介绍了angularjs popup-table 弹出框表格指令,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2017-09-09 AngularJs bootstrap详解及示例代码 本文主要讲解AngularJs bootstrap,这里整理了详细的资料及简单示例代码帮助大家学习或者参考,有需要的小伙伴看下 2016-09-09 Angular动态绑定样式及改变UI框架样式的方法小结 AngularJS 是一个 JavaScript 框架。它是一个以 JavaScript 编写的库。这篇文章主要介绍了Angular动态绑定样式及改变UI框架样式的方法小结,需要的朋友可以参考下 2018-09-09 AngularJS ng-style中使用filter 这篇文章主要介绍了AngularJS ng-style中使用filter的相关资料,需要的朋友可以参考下 2016-09-09 Angular 4 依赖注入学习教程之FactoryProvider的使用(四) 这篇文章主要给大家介绍了关于Angular 4 依赖注入之FactoryProvider使用的相关资料,文中介绍的非常详细,对大家学习或者使用Angular4具有一定的参考学习价值,需要的朋友们下面来一起看看吧。 2017-06-06 AngularJS基础 ng-srcset 指令简单示例 本文主要介绍AngularJS ng-srcset 指令,这里对ng-srcset 指令做了详细的资料整理,附有代码示例,有需要的小伙伴可以参考下 2016-08-08 angular $watch 一个变量的变化(实例讲解) 下面小编就为大家带来一篇angular $watch 一个变量的变化(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧 2017-08-08 最新评论

Angular.js取得的巨大成就之一是实用的异常抛出,因为异常信息经常能够准确的表明你的代码为什么崩溃了。运行于世界各地的众多浏览器的大型客户端web应用会面临异常丢失的问题,而捕获它就有可能修复 bug并赢得用户。

当处理跨浏览器和设备的问题时,接收这些异常信息是很重要的,因为你的应用可能在你的开发机器上运行得正确可靠,但在你的用户的浏览器上却是另一番场景。

其解决方案是需要一个自动异常跟踪服务,而Raygun通过接收你的Angular web应用抛出的所有异常但不需要你做任何事,从而简化了这项工作。它的设置真的很快--只需要按照以下步骤将Raygun hook到你的应用就可以了。

安装

首先,下载小巧的Raygun4JS脚本,并把它添加到你的项目中。有3个途径获得:

通过Bower
 

复制代码 代码如下:
bower install raygun4js

从NuGet获得——在Visual Studio中,打开包管理器控制台然后输入:
 

复制代码 代码如下:
Install-Package raygun4js

手动下载 – 点击此处下载dev版 或者压缩过的版本
配置

接下来,引用这个脚本。如果你使用静态的HTML,将<script src=”js/raygun.js” type=”text/javascript”></script>添加到页面里面或添加到你的模块加载器中。

最后,在你的Angular主逻辑执行之前调用下面的代码来设置Raygun4JS:
 

Raygun.init('YOUR_API_KEY').attach();

你可以为每一个用Raygun创建的app生成一个API key,你可以在你的Raygun dashboard 中访问他——你有30天免费试用时间来测试它。
在Angular中捕获异常

至少有两种方法将未处理的异常注射到Angular.js的模块中,通过使用decorator 或 factory。这两种方式会为你提供$exceptionHandler的具体实现,我们上面所提到的Raygun4JS会将该实现发送给Raygun。

使用一个装饰器

装饰器模式因其不会覆盖掉原有的行为,所以很适合用来将行为注入到任意的服务中,以确保在其它所期望的特性中分离关注点,它也是记录日志和处理异常的理想方式. 在Angular.js中它可以使用在 $provide 服务中,我们将用来实现我们自己的

$exceptionHandler 函数:
 
app.config(function ($provide) {
 $provide.decorator("$exceptionHandler", ['$delegate', function($delegate) {
  return function (exception, cause) {
   Raygun.send(exception);
   $delegate(exception, cause);
  }
 }])
});

$delegate 是异常处理器的实体,我们会调用它来获得输出到控制台的原始行为.

你也可以按照自己的需要创建足够多的其它服务:
 

$provide.decorator("$exceptionHandler", ['$delegate', '$log', function($delegate, $log) {
  return function (exception, cause) {
   $log.debug('Sending to Raygun');
   Raygun.send(exception);
   $delegate(exception, cause);
  }
 }])

依赖于所获取到的自Angular逻辑中抛出的错误是什么类型, cause 参数得以被填充. 如果一个异常发生在一个工厂或者服务中,你可能会得到那个参数可以的范围, 你可以将其作为自定义数据,通过替换掉上面的Raygun.send调用,附带任何你需要的其它东西,再传送到Raygun:
 

Raygun.send(exception, { cause: cause });

使用一个工厂

快速的将Raygun放到你的应用的异常处理器中的方法就是使用一个工厂, 尽管它会移除原来的控制台日志,而如果你想要保留此项功能的话,就会需要存储原来的值并再一次调用它.
 

app.factory('$exceptionHandler', function () {
 return function (exception) {
  Raygun.send(exception);
 }
});

手动发送错误

Raygun4JS 也归于了你任意时间很容易的手动跟踪错误的能力:
 

Raygun.send(new Error('my custom error'));

供应器上还有一堆其它使用的工具可以利用,包括独特的用户跟踪,版本跟踪,标签及其它 – 这里的文档可以查看 的所有相信信息.

Raygun 甚至可以在你的Angular应用中跟踪jQuery 的Ajax错误even tracks jQuery Ajax errors ,而无需你的做任何额外的事情, 因此你将得到开箱即用的全面照顾.
准备好使用Raygun了吗?

如之前所提及的,有一个 30天免费的无信用卡支付的版本可用, 因此你可以获取一个来看看你的应用是否真的是在为你的用户运作的. 如果就本文你有任何的疑问,请将它们留在下面的评论中。

您可能感兴趣的文章:

  • JS异步堆栈追踪之为什么await胜过Promise
  • Java动态追踪技术探究之从JSP到Arthas
  • JS/HTML5游戏常用算法之追踪算法实例详解
  • 详解VueJS 数据驱动和依赖追踪分析
  • JavaScript错误处理和堆栈追踪详解
  • JS脚本实现网页自动秒杀点击
  • 基于JS脚本语言的基础语法详解
  • js脚本编写简单刷票投票系统
  • 如何用JS追踪用户
张贴在3