就像弗兰克所说,您必须了解用户的一些信息才能找到她/他。
但是,这是一个一般性的答案。我假设“名称”是指您创建的属性“标识符”。
建议
简答
- 要通过
identifiant 属性检查用户是否存在,您需要orderByChild("identifiant") 并使用.equalTo("<identifient_here>") 查询特定用户。
例如,检查是否有 identifient="aaa" 的用户,
var usersRef = new Firebase("https://<YOUR-FIREBASE-APP>.firebaseio.com/Users");
var identifient = "aaa";
usersRef.orderByChild("identifiant").equalTo(identifient).once("value", function(snapshot) {
console.log("Loaded user by identifient:",identifient,snapshot.val());
});
- 如果您想通过键查询(例如
simplelogin:53),您可以使用orderByKey() 而不是orderByChild() 进行查询...或者只是将 ref 设置为用户的键,如下所示:
var userKey = 'simplelogin:53';
var userRef = new Firebase("https://<YOUR-FIREBASE-APP>.firebaseio.com/Users" + userKey);
userRef.once("value", function(snapshot) {
console.log("Loaded user",snapshot.val());
});
长(呃)答案
UserFactory 示例
- 看看这个工作PLNKR example。
- 它与我的一个公共 Firebase 实例相关联。
- 我像你一样在
/Users 中创建了相同的simplelogin:53 用户。
- 如果您搜索
identifient = aaa,您将获得正确的用户。
- 此处的控制器实现仅用于示例目的,并没有真正做任何有价值的事情。仅供参考。
数据
{
"Users" : {
"simplelogin:53" : {
"identifiant" : "aaa"
}
}
}
用户工厂
.factory('UserFactory', function($q, $firebaseObject, fbUrl){
return function(userId){
var deferred = $q.defer();
if (userId.isNotEmpty()) {
var userRef = new Firebase(fbUrl + '/Users/').orderByChild("identifiant").equalTo(userId);
userRef.once("value",
function(dataSnapshot){
if (dataSnapshot.val()) {
console.log("Loaded user",dataSnapshot.val());
deferred.resolve(dataSnapshot.val());
} else {
console.info("Couldn't find user by id",userId);
deferred.reject("No user found by identifient = '"+userId+"'");
}
},
function(error){
console.error("Error loading user",error);
deferred.reject(error);
}
);
} else {
deferred.reject("No id entered!");
}
return deferred.promise;
}
})
控制器
.controller('HomeController',function($scope, UserFactory) {
$scope.identifient = '';
var showError = function(errorMessage) {
if (errorMessage) {
showUser(false);
$scope.error = errorMessage;
} else {
delete $scope.error;
}
}
var showUser = function (userObject) {
if (userObject) {
showError(false);
$scope.user = userObject;
} else {
delete $scope.user;
}
}
$scope.loadUser = function() {
var userPromise = new UserFactory($scope.identifient);
userPromise.then(function(data){
showUser(data);
}).catch(function(error){
showError(error);
});
}
})
模板
<div ng-controller="HomeController">
<h2>Home Template</h2>
<input ng-model="identifient" placeholder="identifient"/>
<button ng-click="loadUser()">Find User</button>
<hr/>
<div ng-if="user">User: {{user}}</div>
<div ng-if="error">Error: {{error}}</div>
</div>
希望有所帮助。