Javascript 从app.js触发$modal.open
我的app.js看起来像这样。我需要全局处理AJAX错误。 如果只使用console.log,则此代码可以正常工作。但是,我需要使用$modal触发模态对话框,但不确定如何实现。 感谢您的帮助。谢谢大家!Javascript 从app.js触发$modal.open,javascript,angularjs,angularjs-scope,angularjs-controller,angularjs-provider,Javascript,Angularjs,Angularjs Scope,Angularjs Controller,Angularjs Provider,我的app.js看起来像这样。我需要全局处理AJAX错误。 如果只使用console.log,则此代码可以正常工作。但是,我需要使用$modal触发模态对话框,但不确定如何实现。 感谢您的帮助。谢谢大家! define(['jquery','angularAMD', 'modernizr' ,'angular-ui-router'], function ($, angularAMD) { var app = angular.module('ABC', ['ui.router','angular.
define(['jquery','angularAMD', 'modernizr' ,'angular-ui-router'], function ($, angularAMD) {
var app = angular.module('ABC', ['ui.router','angular.css.injector']),
ngAMD = angularAMD(app);
app.run(function($rootScope){
$rootScope.$on('$stateChangeSuccess', function (ev, to, toParams, from) {
$rootScope.previousState = from.name;
$rootScope.currentState = to.name;
});
});
app.config(function($stateProvider, $urlRouterProvider, $provide, $httpProvider) {
$urlRouterProvider.otherwise("/");
$stateProvider
.state('first',
ngAMD.route({
url:'/first',
templateUrl: 'app/partials/first.html',
controller : 'firstCrtl'
})
)
.state('default',
ngAMD.route({
url:'/',
templateUrl: 'app/partials/default.html',
controller : 'defaultCrtl'
})
);
$provide.factory('globalAjaxInterceptor', function($q) {
return {
// On request success
request: function(config) {
return config || $q.when(config);
},
// On request failure
requestError: function(rejection) {
return $q.reject(rejection);
},
// On response success
response: function(response) {
if(response.data.status === "FAILURE" && response.data.failueCode === "F003") {
console.log('Trigger Modal');
}else if(response.data.status == "SUCCESS"){
console.log('Response Address Successs');
}
// Return the response or promise.
return response || $q.when(response);
},
// On response failture
responseError: function(rejection) {
// Return the promise rejection.
switch (rejection.status) {
case 404:
console.log('Destinaion not found!')
break;
default:
console.log('Trigger Modal');
}
return $q.reject(rejection);
}
};
});
// Add the interceptor to the $httpProvider.
$httpProvider.interceptors.push('globalAjaxInterceptor');
});
ngAMD.bootstrap();
return app;
});
他的问题的解决方案是修复循环依赖错误或Cdep的解决方案。 修复方法是使用$injector显式地注入$modal。解决方案如下所示-
responseError: function(rejection) {
// Return the promise rejection.
switch (rejection.status) {
case 404:
console.log('Destinaion not found!')
break;
default:
$injector.invoke(function($modal) {
$rootScope.errorOverlay($modal);
});
}
return $q.reject(rejection);
}
从globalAjaxInterceptor服务,您可以访问$modal服务,就像$q服务一样。所以像平常一样使用$modal.open。@NikosParaskevopoulos-我这样做时会得到一个cdep循环依赖项。也许这是因为$modal将使用另一个AJAX调用获取其模板。不确定如何执行此操作。@NikosParaskevopoulos-错误:[$injector:cdep]找到循环依赖项:$http