Javascript没有分配给变量

时间:2015-06-09 16:23:48

标签: javascript node.js postgresql

我在Node.js中编写了一个基本的用户创建系统,我想知道createUser函数的结果是什么。代码本身工作正常,新用户被发布,已经存在的用户被停止。我想向最终用户展示这一点,所以我设置了一个变量来返回一个表示结果的数值。

问题是,该值永远不会分配给。即使我的其他日志语句出现,最终的控制台日志也始终是未定义的。我觉得这更像是一个JavaScript语法问题,但我很难过。

User.prototype.createUser = function () {
    console.log('Begin createUser...');
    var email = this.email;
    var wasUserCreated;  <------- variable to assign
    pg.connect(process.env.DATABASE_URL, function (err, client) {
        if (err) {
            console.log(err.message, err.stack);
            wasUserCreated = 0; <------assigning to variable?
        }
        else {
            var query = client.query('SELECT email FROM users WHERE email=$1', [email], 
            function (err, results) {
                if (results.rows.length > 0) {
                    console.log('That email address has already been registered!');
                    wasUserCreated = 1; <------assigning to variable?

                }
                else {
                    console.log('Email address not found, inserting new account');
                    insertNewUser();
                    wasUserCreated = 2; <------assigning to variable?

                }
            });
        }
    });
    console.log("wasUserCreated: " + wasUserCreated); <------always reads 'undefined'

    return wasUserCreated;
};

2 个答案:

答案 0 :(得分:0)

这是因为您的查询是异步的 - 您的createUser方法应该做的是将回调作为参数,并在回调查询中调用cb(err,wasUserCreated,user)。

您的console.log始终是undef,因为它会同步触发

some basics in mixu's node book

答案 1 :(得分:0)

pg.connect 的第二个参数是一个回调函数,它以异步方式运行...所以函数在 wasUserCreated 被修改之前返回

相关问题