我已将 AngularJS-Toaster 库添加到我的 index.html 中:
<link href="lib/angularjs-toaster/toaster.min.css" rel="stylesheet" />
<script src="lib/angularjs-toaster/toaster.min.js"></script>
<toaster-container
toaster-options="{'position-class': 'toast-bottom-center'}">
</toaster-container>
在我的角度应用程序中:
//app.js
(function () {
angular
.module('app', ['toaster','blocks.logger',/*etc*/]);
})();
//blocks/logger/logger.module.js
(function () {
angular.module('blocks.logger', ['toaster']);
})();
//blocks/logger/logger.js
(function () {
'use strict';
angular
.module('blocks.logger')
.factory('logger', logger);
logger.$inject = ['$log', 'toaster'];
function logger($log, toaster) {
var service = {
error: error,
info: info,
success: success,
warning: warning,
log: $log.log // straight to console;
};
return service;
function error(message, title, data) {
toaster.error({ title: title || 'Error', body: message, timeout: 6000 });
$log.error(message, data);
}
//etc
}());
但是当我这样做时,我从注入器中收到循环依赖错误:Uncaught Error: [$injector:cdep]
我究竟做错了什么?
EDIT我发现问题与我使用的异常处理程序有关:
//code lifted from https://github.com/johnpapa/ng-demos (modular)
(function () {
'use strict';
angular
.module('blocks.exception')
.provider('exceptionHandler', exceptionHandlerProvider)
.config(config);
function exceptionHandlerProvider() {
/* jshint validthis:true */
this.config = {
appErrorPrefix: undefined
};
this.configure = function (appErrorPrefix) {
this.config.appErrorPrefix = appErrorPrefix;
};
this.$get = function () {
return { config: this.config };
};
}
function config($provide) {
$provide.decorator('$exceptionHandler', extendExceptionHandler);
}
//function extendExceptionHandler($delegate, exceptionHandler, logger) {
function extendExceptionHandler($delegate, exceptionHandler) {
return function (exception, cause) {
var appErrorPrefix = exceptionHandler.config.appErrorPrefix || '';
var errorData = { exception: exception, cause: cause };
var logMessage = appErrorPrefix + exception.message;
$delegate(exception, cause);
//logger.error(logMessage, errorData);
};
}
})();
通过注释掉记录器的使用,我可以在其他地方使用日志记录。但我也想在这里使用我的记录器。那么这是怎么回事以及如何解决它?