gpt4 book ai didi

javascript - FireBase - angularfire 将对象键设置为变量

转载 作者:行者123 更新时间:2023-11-29 21:38:33 25 4
gpt4 key购买 nike

我在我的 angularjs 应用程序中使用 firebase(angularfire) 来存储和处理我的消息系统,但似乎无法弄清楚如何从 firebase 文档复制示例数据

 // room members are easily accessible (or restricted)
// we also store these by room ID
"members": {
// we'll talk about indices like this below
"one": {
"mchen": true,
"hmadi": true
}
}

这里的 members.one 包含用户名作为键,我也在尝试对我的数据执行此操作,但似乎无法找到解决方案。

我的 firebase 数据的成员部分是这样的:

成员{一:{}}

我在 $scope 中设置了两个变量。

user_name = kep; //person chatting with name
sender_name = pek; //current user name

所以我想使用 set 函数将数据插入 members.one 或在这种情况下 members.user_name + ':' + sender_name 但是我有问题是如何在不创建父对象的情况下实际插入数据。

ref.child('members').child(user_name + ':' + sender_name).set({
user_name: true, sender_name: true
});

当我尝试将 user_name 和 sender_name 传递给 set() 函数时出现问题,下面是它得到的结果。

members { "kep:pek": { user_name: true, sender_name: true }}

如我所愿:

members { "kep:pek": { kep: true, pek: true }}

如果我将 user_name 和 sender_name 放入一个对象中,然后使用传递的对象运行 set() 函数,它将创建以下结构,这不是我想要的:

members { "kep:pek": { newObject: { kep: true, pek: true }}}

最佳答案

这里是 Firebase 团队成员。

Firebase 数据库只是一个 JSON 文档。

假设您想以这种方式构建数据:

{
"members" : {
"kep:pek" : {
"kep" : true,
"pek" : true
}
}
}

通过使用 .child() 方法或通过在 JavaScript 对象中创建键来创建自定义键。

JSBin Demo

var rootRef = new Firebase('<my-firebase-app>');
var membersRef = rootRef.child('members');
var user_name = 'kep';
var sender_name = 'pek';
// child object to store custom keys
var objectToSave = {};
// set keys in [] syntax
objectToSave[user_name] = true;
objectToSave[sender_name] = true;
// use .child() with a formatted string to save the object
membersRef.child(user_name + ':' + sender_name).set(objectToSave);

关于javascript - FireBase - angularfire 将对象键设置为变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34035280/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com