我有一个非常简单的createService
函数,可以将数据发送到我的Firebase。运行时,它会将$scope.serviceTitle
推送到名为services
的对象,并将我的$scope.providerTitle
推送到名为providers
的对象。
main.js
$scope.createService = function() {
var newService = { title: $scope.serviceTitle };
var newProvider = { title: $scope.providerTitle };
var servicePromise = ServiceService.add(newService);
var providerPromise = ProviderService.add(newProvider);
};
ServiceService.js
angular.module('outcomesApp').service('ServiceService', function(FBURL, $firebase) {
var serviceRef = new Firebase(FBURL).child('services');
var fireService = $firebase(serviceRef).$asArray();
return {
add: function addService(service) {
return fireService.$add(service);
}
};
});
我的数据最终看起来像这样:
{
"services": {
"-JgDvQz_opBMdULBPySG": {
"title": "Hernia Repair"
}
},
"providers": {
"-JgDp4zieowSM-ymfDHR": {
"title": "The Whittington Hospital",
}
}
}
我想在运行名为createService()
的{{1}}函数时推送第三个对象,其中service_at_provider
具有我刚刚推送的服务service
的值,.key()
的值为提供者provider
。这可能有助于理解我正在努力实现的目标:
key()
由于{
"services": {
"-JgDvQz_opBMdULBPySG": {
"title": "Hernia Repair"
}
},
"providers": {
"-JgDp4zieowSM-ymfDHR": {
"title": "The Whittington Hospital",
}
},
"service_at_provider": {
"-JgDvQzYxtYGp7JspWYr": {
"service": "-JgDvQz_opBMdULBPySG", // matches the 'newService' just pushed
"provider": "-JgDp4zieowSM-ymfDHR" // matches the 'newProvider' just pushed
}
}
}
,$add
变量返回一个承诺。但我无法弄清楚如何返回servicePromise
并将其传递给同一推送中名为key()
的新对象。
这可能吗?
答案 0 :(得分:0)
$add()返回的promise将解析为新的firebase引用。您可以在createService中执行以下操作。
$q.all([servicePromise, providerPromise]).then(function(refs) {
var serviceRef = refs[0];
var providerRef = refs[1];
// service key
serviceRef.key();
// provider key
providerRef.key();
// Use that data to add to your service_at_provider array
});