作为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;
});
}
任何善良的灵魂都可以指出我哪里出错了吗?我会很感激!!
答案 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("");
}
});