成功在结束回应之前被解雇

时间:2017-05-27 23:09:19

标签: javascript jquery node.js ajax post

作为web dev的初学者,我正在使用pure node.js构建我的第一个web应用程序。 在注册部分,表单数据将从客户端发布到服务器,然后添加到数据库。成功的客户端将根据收到的响应操纵DOM。但是,成功回调始终在发送响应之前触发。

客户端代码:

$.post('/register.db', {
        data: JSON.stringify(user),
        contentType: "application/json",
        dataType: "text",
        success: function(data){
            alert(data);
            if(response == register.exists){
                $(".login-form>input:nth-child(3)").append("<span>This email has already been used</span>");
            }
            else if(response == register.success){
                $(".login-wrapper>span").html("Proceed to login");
                $(".register-wrapper").html("");
            }
        }
    });

服务器端代码:

                    var body = "";
                    req.on("error", function(){
                        handleError();
                    }).on("data", function(chunk){
                        body += chunk;
                    }).on("end", function(){

                        // success callback is fired as soon as request ends
                        // code afterwards is executed after success callback
                        // but response is written in db.register() function
                        var user = JSON.parse(qs.parse(body).data);
                        console.log("user ",user);
                        res.on('error', function(err){
                            handleError();
                        });
                        db.register(res, user);
                    });

---编辑:添加数据库代码---

数据库代码:

register:
        function(res, user){
            var account = user['email'];
            client.sismember('users', account, function(err, response){
                res.statusCode = 200;
                res.setHeader('Content-type', 'text/plain');
                // account already exists
                if(response != 0){
                    res.write(register.exists);
                    res.end();
                    return;
                }
                client.sadd("users", account);
                client.hmset(account, "pin", user.pin, "first_name", user.first_name, "last_name", user.last_name);
                res.write(register.success);
                res.end();
                return;
            });
        }

任何善良的灵魂都可以指出我哪里出错了吗?我会很感激!!

1 个答案:

答案 0 :(得分:0)

我将客户端代码更改为以下内容并且神奇地工作了...我只是用匿名回调函数替换了成功回调...任何人都知道定义成功回调的这两种方式之间的区别?

$.post('/register.db',
            {
                data: JSON.stringify(user),
                contentType: "application/json",
                dataType: "text"
            },
            function(data){
                alert(data);
                if(response == register.exists){
                    $(".login-form>input:nth-child(3)").append("<span>This email has already been used</span>");
                }
                else if(response == register.success){
                    $(".login-wrapper>span").html("Proceed to login");
                    $(".register-wrapper").html("");
                }
            });