Javascript 科尔多瓦与Firebase赢得';行不通

Javascript 科尔多瓦与Firebase赢得';行不通,javascript,android,cordova,firebase,Javascript,Android,Cordova,Firebase,我正在使用Cordova和Firebase创建一个应用程序 我所做的许多函数之一是此函数: function searchForGameRound() { var ref = new Firebase("https://grootproject.firebaseio.com/Users/"); // Dit is de query naar Firebase toe (kan je vergelijken met een query als bij SQL) var query = ref.o

我正在使用Cordova和Firebase创建一个应用程序

我所做的许多函数之一是此函数:

function searchForGameRound() {
var ref = new Firebase("https://grootproject.firebaseio.com/Users/");

// Dit is de query naar Firebase toe (kan je vergelijken met een query als bij SQL)
var query = ref.orderByChild("gameSearching").equalTo(true);
console.log('spelen');

// Hierbij geef ik aan dat hij dit enkel 1x mag doen. Dit voorkomt dat hij dit op elk child gaat uitvoeren (wat meerdere games maakt).
query.once("value", function (data) {
    console.log('spelen', data.val());

    if (data.val() === null) {
        updateData(('Users/' + you + '/'), {gameSearching: true});
        return;
    }
    var alreadyInCurrentGame;

    var object = data.val();
    var user1 = Object.keys(object)[0];
    var user2 = Object.keys(object)[1];

    // Als je het zelf bent
    if (you == user1) {
        if (user2) {
            opponent = user2;
        } else {
            updateData(('Users/' + you + '/'), {gameSearching: true});
            return;
        }
    } else {
        opponent = user1;
    }

    console.log(opponent, 'opponent found');

    // Hierbij gaat hij kijken of er al een currentgame bestaat met deze user
    var ref = new Firebase('https://grootproject.firebaseio.com/Users/' + you + '/currentGames/' + opponent + '/');
    ref.once("value", function (snapshot) {
        if (!snapshot.val() === null) {
            console.log(snapshot.val(), ' bestaat al');
            alreadyInCurrentGame = true;
        }
    }, function (errorObject) {
        console.log(errorObject.error);
    });

    // Als alles goed is, gooit hij er data in.
    if (!alreadyInCurrentGame) {
        console.log('spel gevonden');


        var game = new Firebase("https://grootproject.firebaseio.com/Games/");
        game.on("value", function (data) {

            var length = Object.keys(data.val()).length;

            for (var i = 0; i < length; i++) {
                games.push(Object.keys(data.val())[i]);
            }

            game1 = Math.floor(Math.random() * 4);
            game2 = Math.floor(Math.random() * 4);
            game3 = Math.floor(Math.random() * 4);

            while(game1 == game2){
                game2 = Math.floor(Math.random() * 4);
            }

            while(game2 == game3){
                game3 = Math.floor(Math.random() * 4);
            }

            console.log(games, 'games');
            game1 = games[game1];
            game2 = games[game2];
            game3 = games[game3];
            console.log(game1);
            console.log(game2);
            console.log(game3);

            var url = 'https://grootproject.firebaseio.com/Users/' + opponent + '/currentGames/' + you + '/';
            var fir = new Firebase(url);
            fir.set(
                {

                    round1: {score: '-', game: game1},
                    round2: {score: '-', game: game2},
                    round3: {score: '-', game: game3}
                }
            );

            url = 'https://grootproject.firebaseio.com/Users/' + you + '/currentGames/' + opponent + '/';
            fir = new Firebase(url);
            fir.set(
                {
                    round1: {score: '-', game: game1},
                    round2: {score: '-', game: game2},
                    round3: {score: '-', game: game3}
                }
            );

            url = 'https://grootproject.firebaseio.com/Users/' + you + '/';
            fir = new Firebase(url);
            fir.update(
                {gameSearching: false}
            );

            console.log(opponent, ' opponent');
            url = 'https://grootproject.firebaseio.com/Users/' + opponent + '/';
            fir = new Firebase(url);
            fir.update(
                {gameSearching: false}
            );
        });

    } else {
        updateData(('Users/' + you + '/'), {gameSearching: true});
    }
}, function (err) {
    console.log(err, 'error');
});
似乎每当他使用Firebase时,console.logs都不会显示(该函数也不能完成它的工作)

我得到的唯一console.log是第一个
console.log('spelen')
。这对我来说很奇怪,因为在我的电脑上它工作得很好

此函数不是唯一一个不能正常工作的函数。每次我用Firebase检索手机上的数据时,它都不起作用

我使用的是Cordova和Firebase 2.0.4的最新版本

有什么想法吗


编辑
它似乎只有在我登录到应用程序时才起作用。当我已经登录到firebase(firebase.getAuth())时,该函数将无法工作,并且我将无法从firebase检索任何数据。

如果不使用函数authWithPassword或unauth,firebase似乎无法建立任何连接

我用Firebase.goOnline()解决了我的问题每当应用程序启动时

document.addEventListener("deviceready", function () { 
    Firebase.goOnline();
}

山姆,我想这只是第一个“斯佩伦”日志出现。如果是这样,Firebase不会返回任何数据。你有没有像这里描述的那样把你的火力基地列入白名单?可能firebase js尚未正确加载,因此您的ref.orderByChild行中出现异常?@mentat:在这种情况下,第一个
console.log('spelen')
将不会执行,因为之前会出现错误。我没有将myFirebase列入白名单。我试试看,谢谢!尝试使用
Firebase启用Firebase日志记录。在客户端代码中启用日志记录(true,true)
,并在此处共享任何有趣的发现。
document.addEventListener("deviceready", function () { 
    Firebase.goOnline();
}