【发布时间】:2015-01-04 20:06:04
【问题描述】:
在我的 Angular 应用程序中,我尝试调用一系列函数,每个函数都返回一个值,该值成为下一个函数的输入。从概念上讲,它是这样的:
$scope.createPanel = function() {
var primer3_parameter_id = primer3FromDesignSetting($scope.selector.designSetting);
var panel = getPanelData(primer3_parameter_id);
Restangular.all('batches').post(panel).then(function(batch) {
createBatchDetailRows(batch);
});
};
我发现这行不通,因为远程调用的异步性质:它们返回一个承诺而不是实际结果。
我认为我需要做这样的事情:
$scope.createPanel = function() {
primer3FromDesignSetting($scope.selector.designSetting)
.then(getPanelData(primer3_parameter_id))
.then(postPanel(panel)) // the Restangular call wrapped into a new function
.then(createBatchDetailRows(batch))
.catch(function(err) {
// error handler
}
};
function primer3FromDesignSetting(designSetting) {
var primer3Parameter = _.clone(Restangular.stripRestangular(designSetting));
primer3Parameter = _.omit(primer3Parameter,panelFields);
delete primer3Parameter.id;
Restangular.all('primer3_parameters').post(primer3Parameter).then(function(newPrimer3Parameter)
{
return newPrimer3Parameter.id;
}, function(error) {
console.log(error);
});
}
$scope.createPanel();
但我无法完全理解正确的语法。
【问题讨论】:
标签: javascript angularjs promise angular-promise