我想动态地在Firebase中创建五个新目录.我还想动态地在这些目录中插入数据.我为此目的编写了这个jquery脚本.
for(var i=0; i<5; i++) {
var dataRef = new Firebase('https://blr-reaction-buttons.firebaseio.com/' + i);
dataRef.on('value', function (snapshot) {
var tempdata = snapshot.val();
if (!tempdata) {
tempdata=50;
dataRef.set(tempdata);
}
});
}
Run Code Online (Sandbox Code Playgroud)
但它不是创建多个目录,而是创建一个目录(实际上是最后一个目录)(下图)...

我只是不明白为什么会这样.请帮忙.任何形式的帮助将不胜感激.提前致谢.
Firebase实际上没有目录,但所有内容都是JavaScript对象.这意味着与目录最接近的是包含另一个对象的键:)
换句话说,我假设你想在Forge看到这样的东西:

要使Firebase看起来像这样,您可以在本地创建JavaScript对象并使用它将其保存到根节点set.然后,您可以使用读取回调value来侦听更改.这是实现这个的代码:
<html>
<head>
<script src='https://cdn.firebase.com/js/client/1.0.15/firebase.js'></script>
<script src='https://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js'>
</script>
</head>
<body>
<script>
/* Write 5 numbered objects, each set to 50 */
// Create a new Firebase data reference to the root
var dataRef =
new Firebase('https://test-firebase-please-ignore.firebaseio.com/');
// Create a JavaScript object to hold stuff
var tempData = {};
// Add 5 things to it
for(var i=0; i<5; i++) {
tempData[i] = {value: 50};
}
// Save it to Firebase
dataRef.set(tempData);
/* Meanwhile, create a listener that gets updates when the data changes */
dataRef.on('value', function(snapshot) {
// Log the whole thing
console.log(snapshot.val());
});
</script>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1371 次 |
| 最近记录: |