我有以下数据结构
{
"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对象。
答案 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()
,因为当它可用时,它将在您的模板中使用。