我试图执行firstFunction()
来解析一个csv文件并返回一些数据,然后将其传递给secondFunction()
以执行一些操作。我已经分别测试了它们,并且它们都按预期工作,但是在secondFunction()
完成之后,我无法让firstFunction()
执行。这导致在执行时未定义“数据”。
function parentFunc(){
firstFunction(function(data){
secondFunction(data);
});
}
function firstFunction(){
var inputFile = 'import.csv';
var dataOutput = [];
var colHead = [];
var parser = parse({delimiter: ','}, function(err, data){
colHead.push(data[0][0],data[0][1],data[0][2],data[0][3],data[0][4]);
for( i = 1; i<data.length; i ++ ){
var line = {[colHead[0]]:data[i][0],
[colHead[1]]:data[i][1],
[colHead[2]]:data[i][2],
[colHead[3]]:data[i][3],
[colHead[4]]:data[i][4]};
dataOutput.push(line);
}
});
var readStream = fs.createReadStream(inputFile).pipe(parser);
readStream.on('end', function(){
return dataOutput;
})
}
async function secondFunction(data){
for(i=0; i<data.length;i++){
//some operations with data, using await keyword.
}
}
parentFunc();
我觉得解决方案不应该那么困难,可能是由于我的基本误会。
如果需要更多信息,请告诉我。
答案 0 :(得分:0)
您可以从firstFunction返回promise
function sometestFunction() {
return Math.random();
}
function secondFunction(data) {
console.log('data received from first function ' + data)
}
function firstFunction() {
return Promise.resolve(sometestFunction())
}
firstFunction().then(function(data) {
secondFunction(data);
})
在您的情况下,使用async
await
似乎是错误的。 await
总是放在async
内部。因此,将async
与父函数一起使用,并将await
与firstFucntion一起解析
async function parentFunc() {
let x = await firstFunction();
secondFunction(x);
}
function firstFunction() {
return new Promise(function(resolve) {
setTimeout(() => {
resolve([1, 2, 3, 4, 5, 6]);
}, 3000)
})
}
function secondFunction(data) {
for (var i = 0; i < data.length; i++) {
console.log(data[i])
}
}
parentFunc();
答案 1 :(得分:0)
发生这种情况的原因是因为解析您的csv
文件是异步操作。
要确保在secondFunction
之后执行firstFunction
,您将需要使用promise或async / await。
基本上就是这样:
function parentFunc() {
firstFunction().then(secondFunction)
}
async function parentFunc() {
let data = await firstFunction()
secondFunction(data)
}
以下是有关promise和async / await的其他资源:
希望有帮助!