我有这段代码。
function handleRequest(req, res)
{
req.on('data', parseInput);
res.write(generateInputform());
}
http.createServer(handleRequest).listen(port, ipAddress);
req.on回调parseInput并按字面意思执行函数调用,它解析输入并设置引脚等。然后生成另一个输入表单并呈现给用户。
但是,node.js首先生成输入然后解析输入...这意味着用户必须刷新页面以反映给定的命令。解析输入有效,我可以通过逻辑分析器看到引脚切换提交。
我似乎陷入了困境,因为我找不到这个答案的简单解决方案。显示承诺的那些处理异步延迟,我宁愿避免。
也许有人可以解释这个问题?
这里是完整的handleRequest。
function handleRequest(req, res)
{
switch( req.url )
{
case "/markings.css" :
res.writeHead(200, {'Content-Type': 'text/css'});
res.end("Literally nothing right now");
break;
case "/json" :
res.writeHead(200, {'Content-Type': 'text/json'});
res.end(encapsulator(J17_1, J18_1, J19_14, J20_14));
break;
case "/index":
res.writeHead(200, {'Content-Type': 'text/html'});
res.end(getHTML());
break;
case "/":
// show the user a simple form
console.log("[200] " + req.method + " to " + req.url);
res.writeHead(200, "OK", {'Content-Type': 'text/html'});
switch( req.method )
{
case 'POST':
//Problems between here
req.on('data', parseInput);
res.write(generateInputform());
//And here
console.log("Done");
res.end();
break;
case 'GET':
console.log("User probably refreshed page without entering anything useful");
res.write(generateInputform());
console.log("Done");
res.end();
break;
default:
console.log("?");
res.end();
break;
}
//res.end();
break;
default:
res.writeHead(404, {'Content-Type': 'text/html'});
res.end('<!DOCTYPE html>\r\n<html>\r\n<body>\r\n404, that means trouble.<br><a href="http://' +
ipAddress + ':' + port + '">Go back to the index</a></body></html>');
break;
}
}
编辑:
在此处找到答案。
callback
新句柄请求
req.on('data', parseInput);
req.on('end', function()
{
res.write(generateInputform());
console.log("Done");
res.end();
});
答案 0 :(得分:1)
这是因为Node.js(和javascript)异步运行而不是同步运行,因为您可能与其他语言一起使用。这意味着当一个线程在后台执行I / O操作时,允许主线程运行。所以在你的情况下&#34; generateInputform()&#34;在仍在解析输入时执行。
您的问题的解决方案是使用回调。 我建议你阅读本教程以理解这个概念:http://www.tutorialspoint.com/nodejs/nodejs_callbacks_concept.htm
答案 1 :(得分:1)
您只是定义req
对象接收数据时会发生什么:
req.on("data", parseInput);
这是直接执行的:
res.write(generateInputform());
generateInput
可能需要进入parseInput
。
答案 2 :(得分:1)
您仍在说“当您收到数据时,请执行此操作”,然后执行“现在执行此操作”。 “now do that”将直接执行,而第一个只表示它正在等待数据。您将接收数据的事件发生很多,可能在下一个循环中。 (不知道节点是如何完成的)