这是我正在使用的软件包的版本:
node.js 0.10.3
express 3.4.4
jade 0.35.0
xml2js 0.2.8
我遇到了一个奇怪的问题,我的第二个ajax请求(/ tasks之一)处于暂停状态几分钟。
我的javascript调用:
$('#add-task').click(function(){
$.post('/addTask', function(){
loadTasks();
});
});
function loadTasks(){
$.get('/tasks', function(tasks){
$('#tasks > tbody').html(tasks);
});
}
这里我的路线档案:
exports.addTask = function(req, res){
fs.readFile(xmlPath, function(err, data) {
parser.parseString(data, function (err, result) {
var ws = fs.createWriteStream(xmlPath),
xw = new XMLWriter(true, function(string, encoding) {
ws.write(string, encoding);
});
xw.startDocument('1.0', 'UTF-8').startElement(function() {
return 'tasks';
});
for(var i in result.tasks.task) {
var task = xmlTaskToObject(result.tasks.task[i]);
writeTaskToXml(xw, task);
}
req.body.index = (result.tasks.task !== undefined) ? result.tasks.task.length : 0;
writeTaskToXml(xw, req.body);
xw.endElement();
ws.end();
res.send('');
});
});
};
exports.tasks = function(req, res){
var tasks = [];
fs.readFile(xmlPath, function(err, data) {
if(err){
throw err;
}
parser.parseString(data, function (err, result) {
console.log("AFTER PARSER");
// parsing stuff
/*
...
*/
res.render('tasks', { tasks: tasks });
});
});
};
“AFTER PARSER”永远不会在控制台中显示,也不会抛出异常......
我找到解决问题的唯一方法是使用超时执行第二次ajax调用,如下所示:
$.post('/addTask', function(){
setTimeout(loadTasks, 100);
});
有人可以告诉我出了什么问题?我想这是一个文件访问问题或类似的东西。
谢谢!
答案 0 :(得分:2)
您没有发送回复。 res.render
不会执行res.send。
这应该有效:
res.render('tasks', { tasks: tasks },
function(err, html) { res.send(html); } );
修改强> 问题的另一部分是关闭文件。您需要等待.end()完成(http://nodejs.org/api/stream.html#stream_writable_end_chunk_encoding_callback):
xw.endElement();
ws.on('finish', function() {
res.send('');
});
ws.end();