将Firebase .key()推送到Object

时间:2015-01-22 00:33:10

标签: javascript firebase angularfire

我有一个非常简单的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()的新对象。

这可能吗?

1 个答案:

答案 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
});