Установка собственного ключа при добавлении объекта в Firebase - AngularFire
Я могу использовать следующее для добавления объекта в хранилище данных Firebase:
var uniqueId = {
name: "a name",
location: "new york"
}
$scope.myItems.$add(uniqueId).then(function(firebaseId){
// do something on success
}, function(){
// do something if call fails
});
Вышеуказанное добавит объект в мое хранилище данных, и если добавление будет успешным, возвращается идентификатор, сгенерированный Firebase. Объект, который я только что добавил, сохраняется под этим ключом.
Есть ли способ указать, что такое имя ключа, когда я добавляю в хранилище данных?
Ответы
Ответ 1
Все в Firebase - это URL.
Возьмите, например, следующий URL.
https://myapp.firebaseio.com/users/
Предположим, мы хотим создать пользователя с ключом 1 в качестве ребенка в этом месте. Наш URL-адрес будет выглядеть следующим образом.
https://myapp.firebaseio.com/users/1
Чтобы создать пользователя с помощью AngularFire, мы можем создать ссылку у пользователей node и вызвать $child (1), чтобы создать ссылку на это место.
var usersRef = new Firebase('https://myapp.firebaseio.com/users');
var userRef = new Firebase('https://myapp.firebaseio.com/user/1');
$scope.users = $firebase(usersRef);
// these are the same
$scope.userOne = $firebase(userRef);
$scope.userOne = $scope.users.$child(1);
Затем мы можем использовать $set
для хранения значения пользователя в этом месте.
var usersRef = new Firebase('https://myapp.firebaseio.com/users');
$scope.users = $firebase(usersRef);
$scope.users.$child(1).set({
first: 'Vincent',
last: 'Van Gough',
ears: 1
});
В вашем случае это будет:
var uniqueId = {
id: 1,
name: "a name",
location: "new york"
};
$scope.myItems.$child(uniqueId.id).$set(uniqueId);
Помните, что использование $set
приведет к уничтожению любых предыдущих данных в этом месте. Для неразрушающего обновления значений используйте $update
.
Ответ 2
Вы можете попробовать это следующим образом:
var empsRef = ref.child("employees");
empsRef.child('11111').set({
lastname: "Lee",
firstname: "Kang"
});
empsRef.child('22222').set({
lastname: "Nut",
firstname: "Dough"
});
Результат должен выглядеть следующим образом:
"employees" : {
"11111" : {
"lastname" : "Lee",
"firstname": "Kang"
},
"22222" : {
"lastname" : "Nut",
"firstname": "Dough"
}
}
Ответ 3
Похоже, что $child и $set были удалены из API AngularFire.
Вот мое обходное решение.
- Прослушать $onAuth
- Создайте новый объект $firebaseObject с ref как дочерний элемент пользователя, а id - как uid (в данном случае, facebook).
-
Сохранить объект пользователя
angular.module("app.services", []).factory("Auth", function ($firebaseAuth, $firebaseObject, FirebaseUrl) {
var auth = $firebaseAuth(new Firebase(FirebaseUrl));
auth.$onAuth(function (authData) {
if (authData) {
var ref = new Firebase(FirebaseUrl + "/users/" + authData.uid);
var user = $firebaseObject(ref);
user.name = authData.facebook.displayName;
user.$save().then(function () {
console.log(user);
});
}
});
return auth;
})
Я все еще изо всех сил стараюсь сделать это поддающимся проверке, хотя...
Ответ 4
.set все еще работает в angularfire api
Итак, попробуйте это...
var gT = $scope.ultima[0].guia + 1;
var _db = firebase.database().ref('/guias/' + gT);
_db.set({
'artigo': _dt.artigo,
'inicio': $scope.ultima[0].fim + 1,
'guia': $scope.ultima[0].guia + 1,
'fim': $scope.ultima[0].fim + 1 + (1 * _dt.quantidade),
'quantidade': _dt.quantidade,
});