リクエストが完了した場合にのみ、を$routeProvider
に入れて新しいルートを表示しようとしています。要求が成功すると、$ http.post()の結果が確定し、ビューがレンダリングされます。しかし、要求が失敗した場合(タイムアウトや内部エラーなど)、約束は決して解決されず、ビューはレンダリングされません。 resolve
を使用してリクエストの失敗を処理するにはどうすればよいですか?
コードの最も重要な部分は怒鳴るです:
app.js
$routeProvider.when('/warrantyResult', {
templateUrl : 'partials/warranty-result.html',
controller : 'WarrantyResultCtrl',
resolve : {
response : [ 'Warranty', function(Warranty) {
return Warranty.sendRequest();
} ]
}
});
controllers.js
angular.module('adocDemo.controllers', []).controller('HomeCtrl', [ '$scope', function($scope) {
} ]).controller('WarrantyCtrl', [ '$scope', '$http', '$location', 'Warranty', function($scope, $http, $location, Warranty) {
$scope.submitWarranty = function() {
$scope.loading = true;
Warranty.setRequestData($scope.data);
$location.path('/warrantyResult');
};
} ]).controller('WarrantyResultCtrl', [ '$scope', 'Warranty', function($scope, Warranty) {
$scope.request = Warranty.getRequestData();
$scope.response = Warranty.getResponseData();
} ]);
services.js
angular.module('adocDemo.services', []).factory('Warranty', [ '$http', '$timeout', function($http, $timeout) {
/**
* This service is used to query the Warranty Webmethod. The sendRequest
* method is automaticcaly called when the user is redirected to
* /warrantyResult route.
*/
var isDataSet = false;
var requestData = undefined;
var responseData = undefined;
return {
setRequestData : function(data) {
//Setting the data
isDataSet = true;
},
getRequestData : function() {
return requestData;
},
sendRequest : function(data) {
if(isDataSet) {
var request = $http.post('url/to/webservice', requestData);
request.success(function(data) {
responseData = data;
});
return request;
}
},
getResponseData : function() {
return responseData;
}
};
} ]);
私が知っています私は約束を使用することができます$ httpの呼び出しをラウンドし、要求が失敗であってもそれを解決しますが、単純な解決方法があるのだろうかと思います。うまくいけば
読んでくれてありがとうと、深い検索後:)
解決に失敗したときのアプリの振る舞いに依存しますか? – Stewie
解決が失敗したときに、ユーザーを別のルート(/ requestError?)にリダイレクトするのが最善の動作です。または、/ warrantyResultをレンダリングして、このルートのコントローラが要求が成功したかどうかをチェックすることができます。 – pdegand59