的问候, 马塞洛
// ---- listFiles.js -----------------------------------------------------------
exports.walk = function(currentDirPath, extension, callback) {
var fs = require('fs');
var regex = new RegExp( extension + '$', 'g' );
fs.readdir( currentDirPath, function (err, files) {
if (err) callback(err);
files.filter(function(fname){
if(fname.match(regex)) {
callback(null, fname);
}
})
});
console.log("Fired callback.");
}
// walk('.', 'js', function(err, file){ console.log(file); }); runs OK
// ---- listfilesTest.js --------------------------------------------------------
var http = require('http');
var content = require('./listFiles');
var args = process.argv.slice(2);
console.log(args); // command line arguments (dir & extension)
http.createServer(function (req, res) {
var files = [];
res.writeHead(200, {'Content-Type': 'text/plain'});
res.write('-- list of files --\n');
content.walk(args[0], args[1], function(err, data){
if(err) console.error(err);
//console.log(data);
res.write(data); // not printing the dir Listings
} );
res.end();
}).listen(9000);
// nodemon listFilesTest.js '.' 'js'
答案 0 :(得分:0)
在执行任何res.end()
语句之前,您正在调用res.write()
。对content.walk()
的回调是异步的,这意味着它将来会发生一些不确定的时间。
您需要在完成所有res.end()
语句后调用res.write()
。 exports.walk()
的结构方式,调用者无法知道何时完成列出文件并调用回调,因此必须对其进行重组以指示何时完成。
有许多可能的方法来构建它。一个相当简单的方法是在回调中添加一个参数,该信号在列表完成时发出信号。
// ---- listFiles.js -----------------------------------------------------------
exports.walk = function(currentDirPath, extension, callback) {
var fs = require('fs');
var regex = new RegExp( extension + '$', 'g' );
fs.readdir( currentDirPath, function (err, files) {
if (err) callback(err);
files.filter(function(fname){
if(fname.match(regex)) {
// call the callback with this filename, not done yet
callback(null, false, fname);
}
})
// signal that we are done listing the files
callback(null, true);
console.log("Done listing files.");
});
}
// walk('.', 'js', function(err, done, file){ console.log(file); }); runs OK
// ---- listfilesTest.js --------------------------------------------------------
var http = require('http');
var content = require('./listFiles');
var args = process.argv.slice(2);
console.log(args); // command line arguments (dir & extension)
http.createServer(function (req, res) {
var files = [];
res.writeHead(200, {'Content-Type': 'text/plain'});
res.write('-- list of files --\n');
content.walk(args[0], args[1], function(err, done, data){
if(err) {
console.error(err);
return;
}
if (done) {
res.end();
} else {
//console.log(data);
res.write(data); // not printing the dir Listings
}
});
}).listen(9000);