这是我正在使用的软件包版本:
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 });
});
});
};
“解析器之后”永远不会显示在控制台中,也不会抛出异常......
我发现解决问题的唯一方法是在超时的情况下进行第二次 ajax 调用,如下所示:
$.post('/addTask', function(){
setTimeout(loadTasks, 100);
});
有人可以告诉我怎么了?我猜这是文件访问问题或类似问题。
谢谢 !