繁体   English   中英

javascript 回调 function 同步

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM