使用带有OrderByChild的Firebase查询数据

时间:2016-01-13 09:42:53

标签: javascript angularjs firebase angularfire

我有以下数据结构

{
  "advisors" : {
    "0ea9bab6-415e-4900-8698-ac03a1ef4518" : {
      "description" : "",
      "price" : 0,
      "title" : ""
    },
    "cc31c353-ca6a-440d-b188-af2016f72aef" : {
      "description" : "",
      "price" : 0,
      "title" : ""
    },
    "d8403e9b-fb74-4425-874f-2d125cd07a68" : {
      "description" : "I know every corner in the arab countries.",
      "price" : "50",
      "title" : "Best guide in the middle east"
    }
  },
  "advisors-countries" : {
    "0ea9bab6-415e-4900-8698-ac03a1ef4518" : {
      "Angola" : "true"
    },
    "cc31c353-ca6a-440d-b188-af2016f72aef" : {
      "Angola" : "true"
    }
  },

我想提出以下问题:向我提供其名单中安哥拉顾问的所有价格。

我尝试了下一个代码,仅检索安哥拉=真实的Advisor国家的孩子。

var advisors = (ref.orderByChild("Angole").equalTo(true));
$scope.users = $firebaseArray(advisors);
console.log("sync ", $scope.users);

但是我一直在顾问对象中获取null对象。

1 个答案:

答案 0 :(得分:5)

要使用AngularFire轻松查询,您需要重新设计数据结构。

"advisors-countries" : {
    "0ea9bab6-415e-4900-8698-ac03a1ef4518" : {
      "Angola" : "true",
      "price": 0
    },
    "cc31c353-ca6a-440d-b188-af2016f72aef" : {
      "Angola" : "true",
      "price": 0
    }
}

您应该在advisors-countries位置包含价格和任何其他相关数据。如果您担心重复数据,那没关系。 You can use multi-path updates to keep your data consistent

然后您的查询将起作用:

var query = ref.orderByChild("Angola").equalTo(true);

现在,为什么你看到$scope.users为空。

当您将$scope.users记录到控制台时,它将是null,因为最初没有数据。下载数据是一种异步操作,因此最初不可用。

要调试此操作,请使用$loaded()

$scope.users = $firebaseArray(advisors);
$scope.users.$loaded().then(function(data) {
  console.log(data);
  console.log(data === $scope.users);
});

在第一个日志中,您将获得存在的任何数据。在第二个日志中,您将看到data参数与$scope.users对象相同。这意味着您没有使用$loaded(),因为当它可用时,它将在您的模板中使用。