Luc*_*kyy 7 javascript firebase
我试图从两个表中获取数据(获取所有用户及其详细信息)
tableOne.on('users', function (snapshot) {
userId = snapshot.val().userId; // line 1 (results like 1,2,3,4,5,6)
anotherTable.child('userdetails').child(userId).once('value', function(mediaSnap) {
// result // line 2
});
});
Run Code Online (Sandbox Code Playgroud)
但问题是第1行首先执行6次,然后第2行执行n次,导致每次都在寻找"用户ID为 - 6"... Firebase中是否支持加入?
任何帮助都是相关的
您的代码段有一个令人讨厌的副作用:
var userId;
tableOne.on('value', function (snapshot) {
userId = snapshot.val().userId; // line 1 (results like 1,2,3,4,5,6)
anotherTable.child('userdetails').child(userId).once('value', function(mediaSnap) {
console.log(userId + ":" + mediaSnap.val().name);
});
});
Run Code Online (Sandbox Code Playgroud)
您没有声明userId为变量,这意味着它成为JavaScript中的全局变量.由于回调函数是异步执行的,因此全局值很可能会在您需要时发生变化.
解决方案只是创建userId回调函数的局部变量:
tableOne.on('value', function (snapshot) {
var userId = snapshot.val().userId; // line 1 (results like 1,2,3,4,5,6)
anotherTable.child('userdetails').child(userId).once('value', function(mediaSnap) {
console.log(userId + ":" + mediaSnap.val().name);
});
});
Run Code Online (Sandbox Code Playgroud)
这将确保userId在函数内捕获每个值.
| 归档时间: |
|
| 查看次数: |
14550 次 |
| 最近记录: |