我正在使用ui.router和Restangular。在$stateProvider
我有状态
resolve: {
dane: function (daneTematy) {
var promise = daneTematy.getItem(-1);
return promise;
}
}
对于测试,它总是错误并执行 $stateChangeError
这是服务中的功能:
function getItem(id, params) {
return Restangular.one(zrodlo, id).get()
.then(getItemSuccess)
.catch(restangularError);
function getItemSuccess(response) {
$log.info('Mam dane elementu - Źródło: ' + zrodlo);
response.doHistorii();
return response;
}
}
function restangularError(response) {
$log.error("Error with status code", response.status);
return response;
}
它无法正常工作-可以达到restangularError
但不能达到目标$stateChangeError
。当我删除catch
它时效果很好:
function getItem(id, params) {
return Restangular.one(zrodlo, id).get()
.then(getItemSuccess);
function getItemSuccess(response) {
$log.info('Mam dane elementu - Źródło: ' + zrodlo);
response.doHistorii();
return response;
}
}
有什么问题restangularError
吗?如何解决?
在错误处理程序中,将错误标记为已解决。这样ui-router
就得到了解决的承诺,因此不会导致$stateChangeError
。为了解决这个问题,如果您无法解决问题,则必须在错误处理程序中拒绝一个承诺。请参阅角度文档中的以下摘录:
在将延迟/承诺与熟悉的try / catch / throw行为进行比较时,请将拒绝视为JavaScript中的throw关键字。这也意味着,如果您通过promise错误回调“捕获”错误,并且想要将错误转发到从当前promise派生的promise,则必须通过返回通过reject构建的拒绝来“ throwth”错误。
promiseB = promiseA.then(function(result) {
// success: do something and resolve promiseB
// with the old or a new result
return result;
}, function(reason) {
// error: handle the error if possible and
// resolve promiseB with newPromiseOrValue,
// otherwise forward the rejection to promiseB
if (canHandle(reason)) {
// handle the error and recover
return newPromiseOrValue;
}
return $q.reject(reason);
});
对于您的情况,这仅意味着您必须按以下方式修改错误处理程序(确保$q
可用):
function restangularError(response) {
$log.error("Error with status code", response.status);
return $q.reject(response);
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句