让我们说这是我的代码(我只是写了一个示例来展示这个想法)
var extract = require("./postextract.js");
var rescore = require("./standardaddress.js");
RunFunc();
function RunFunc() {
extract.Start();
console.log("Extraction complete");
rescore.Start();
console.log("Scoring complete");
}
而且我不想让rescore.Start()运行直到整个extract.Start()完成。这两个脚本内部都包含一个蜘蛛网函数,因此直接在Start()函数中放置回调似乎不可行,因为最终函数不会返回该函数,并且在理解如何使用Promises方面遇到很多麻烦。我可以通过哪些方式进行这项工作?
这些是extract.Start()开始和结束的脚本。 OpenWriter()通过其他多个函数和流获得,实际的fileWrite.write()位于附加到该脚本的另一个脚本中(尽管不需要检测运行结束。目前,fileWrite.on('finish')是我希望确定脚本完成的位置
module.exports = {
Start: function CodeFileRead() {
//this.country = countryIn;
//Read stream of thate address components
fs.createReadStream("Reference\\" + postValid.country + " ADDRESS REF DATA.csv")
//Change separator based on file
.pipe(csv({escape: null, headers: false, separator: delim}))
//Indicate start of reading
.on('resume', (data) => console.log("Reading complete postal code file..."))
//Processes lines of data into storage array for comparison
.on('data', (data) => {
postValid.addProper[data[1]] = JSON.stringify(Object.values(data)).replace(/"/g, '').split(',').join('*');
})
//End of reading file
.on('end', () => {
postValid.complete = true;
console.log("Done reading");
//Launch main script, delayed to here in order to not read ahead of this stream
ThisFunc();
});
},
extractDone
}
function OpenWriter() {
//File stream for writing the processed chunks into a new file
fileWrite = fs.createWriteStream("Processed\\" + fileName.split('.')[0] + "_processed." + fileName.split('.')[1]);
fileWrite.on('open', () => console.log("File write is open"));
fileWrite.on('finish', () => {
console.log("File write is closed");
});
}
编辑:我不想简单地将下一个脚本添加到上一个脚本的末尾并放弃主文件,因为我不知道它将持续多长时间,并且它应该被设计为能够占用更多时间超过我们开发阶段的脚本。我不能仅使用现有的软件包,因为在公司中的批准时间最多需要两周,而我更需要此。
双重编辑:这是我的全部代码,每个脚本和功能都是我编写的,因此我可以使被调用的脚本执行所需的操作
您可以将函数包装在Promise中并返回它。
module.exports = {
Start: function CodeFileRead() {
return new Promise((resolve, reject) => {
fs.createReadStream(
'Reference\\' + postValid.country + ' ADDRESS REF DATA.csv'
)
// .......some code...
.on('end', () => {
postValid.complete = true;
console.log('Done reading');
resolve('success');
});
});
}
};
并像这样运行RunFunc:
async function RunFunc() {
await extract.Start();
console.log("Extraction complete");
await rescore.Start();
console.log("Scoring complete");
}
//or IIFE
RunFunc().then(()=>{
console.log("All Complete");
})
注意:当发生某些错误时,您也可以/应该通过reject("some error")
处理错误。
编辑了解TheFunc()之后:
制作新的事件发射器可能是最简单的解决方案:eventEmitter.js
const EventEmitter = require('events').EventEmitter
module.exports = new EventEmitter()
const eventEmitter = require('./eventEmitter');
module.exports = {
Start: function CodeFileRead() {
return new Promise((resolve, reject) => {
//after all of your code
eventEmitter.once('WORK_DONE', ()=>{
resolve("Done");
})
});
}
};
function OpenWriter() {
...
fileWrite.on('finish', () => {
console.log("File write is closed");
eventEmitter.emit("WORK_DONE");
});
}
并且像以前一样运行RunFunc。
没有通用的方法可以确定何时函数调用完成的所有操作。
它可能接受回调。它可能会返回一个承诺。它可能不提供任何方法来确定何时完成。您可能会通过轮询来监视它的副作用。
您需要阅读该特定功能的文档和/或源代码。
使用异步/等待(承诺),例如:
var extract = require("./postextract.js");
var rescore = require("./standardaddress.js");
RunFunc();
async function extract_start() {
try {
extract.Start()
}
catch(e){
console.log(e)
}
}
async function rescore_start() {
try {
rescore.Start()
}
catch(e){
console.log(e)
}
}
async function RunFunc() {
await extract_start();
console.log("Extraction complete");
await rescore_start();
console.log("Scoring complete");
}