[英]javascript callback function synchronise
我目前正在研究 Alexa Skill 以从 SAP 系统收集数据。 由于我的 function 中有一个回调来收集数据,因此 Alexa 在 speakOutput 变量更新之前会说话。
const LagerhueteIntent = {
canHandle(handlerInput) {
return Alexa.getRequestType(handlerInput.requestEnvelope) === 'IntentRequest' &&
Alexa.getIntentName(handlerInput.requestEnvelope) === 'LagerhueteIntent';
},
handle(handlerInput) {
let speakOutput;
console.log("test");
findWarehouseKeepers(function(warehouseKeeper) {
console.log(warehouseKeeper);
speakOutput = "Die Lagerhüter sind die Produkte mit den Ids" + warehouseKeeper;
console.log(speakOutput);
});
return handlerInput.responseBuilder
.speak(speakOutput)
//.reprompt('add a reprompt if you want to keep the session open for the user to respond')
.getResponse();
}
};
使用我的 function:
function findWarehouseKeepers(callback) {
var args = getArgs();
console.log(args);
var Client = require('node-rest-client').Client;
var client = new Client();
client.get("http://XXXXXXXX$format=json", args, function(data, response) {
let validValuesList = new List([]);
data.d.results.forEach(function(data) {
validValuesList.add(data.ProductId);
});
console.log(validValuesList);
let validValuesAsArray = validValuesList.toArray();
console.log(validValuesAsArray);
callback(validValuesAsArray);
});
}
如何让我的 function 同步,以便在执行下一个代码之前更新 speakOutput 变量? 提前致谢。
根据文档, handle
可以返回promise ,这将允许您在收到数据后构建响应。
理想情况下,您应该更改findWarehouseKeepers
以返回 promise,但这里是一个对您的代码进行最小更改的示例:
handle(handlerInput) {
return new Promise(resolve => {
findWarehouseKeepers(warehouseKeeper => {
const speakOutput = "Die Lagerhüter sind die Produkte mit den Ids" + warehouseKeeper;
resolve(
handlerInput.responseBuilder
.speak(speakOutput)
.getResponse()
);
});
});
}
当然,您还想考虑如果请求失败该怎么办,即您想拒绝promise。
如果您更改findWarehouseKeepers
以返回 promise 那么您可能可以将声明handle
编写为async
(我不知道此代码在哪个环境中运行)并以看起来同步的方式编写代码:
async handle(handlerInput) {
const warehouseKeeper = await findWarehouseKeepers();
return handlerInput.responseBuilder
.speak("Die Lagerhüter sind die Produkte mit den Ids" + warehouseKeeper)
.getResponse()
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.