Трудно ми е да разбера идеята за обещания (в angularjs).
Мислех, че мога да дефинирам функция, която връща обещание. Потребителят на това обещание може да работи с него и може също да върне някои данни или обещание.
Но този прост пример се държи неочаквано: първото .then()
извикване връща отхвърляне, но второто then()
извикване изпълнява функцията за успех.
angular.module('myexample', []).controller('Ctrl', ['$scope', '$q',
function($scope, $q) {
$scope.sdfsdf = "";
$scope.action = function() {
$('#msg').html("");
$.Deferred().resolve()
.then(function(response) {
$('#msg').html("error during processing of data!");
return $q.reject('my-failure-reason');
})
.then(
function(data) {
$('#msg').html($('#msg').html() + "<br>success: " + data);
},
function(data) {
$('#msg').html($('#msg').html() + "<br>failure: " + data);
}
);
};
}
]);
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.5/angular.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<body ng-app="myexample">
<div ng-controller="Ctrl">
<button ng-click="action()">Go!</button>
<div id="msg"></div>
</div>
</body>
Разгледах подобните въпроси, но не мога да намеря разликата между моя подход и този в приетите отговори (напр. това един)