程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了如何在 Dialogflow GUI 上使用 fetch 显示 API 数据大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决如何在 Dialogflow GUI 上使用 fetch 显示 API 数据?

开发过程中遇到如何在 Dialogflow GUI 上使用 fetch 显示 API 数据的问题如何解决?下面主要结合日常开发的经验,给出你关于如何在 Dialogflow GUI 上使用 fetch 显示 API 数据的解决方法建议,希望对你解决如何在 Dialogflow GUI 上使用 fetch 显示 API 数据有所启发或帮助;

我想在 Dialogflow GUI 上显示来自 OMDB API 的数据,但它没有发生。数据在 Google Cloud Console 上显示良好。

function infoHandler(agent){
    let movIename = agent.parameters.movIE;
    agent.add(`The information for ${movIename} is as follow`);
    fetch('http://www.omdbAPI.com/?APIkey=e255decd%20&s='+ movIEName)
    .then(result => result.Json())
    .then((Json) => {
        let ID = Json.Search[0].imdbID;
        fetch('http://www.omdbAPI.com/?APIkey=e255decd%20&i=' + ID)
            .then(result => result.Json())
            .then((Json) => {
                agent.add(Json.title + Json.Plot + Json.imdbRaTinng);
          return;
            }).catch((eX) => {
                console.log(eX);
            });
    })
    .catch((E) => {Console.log(E);});
          

解决方法

问题在于 fetch() 会导致异步操作。但是,没有任何内容向 Dialogflow 处理程序调度程序表明它是异步的,并且它应该等待它完成后再发回回复。为此,您需要返回一个 Promise。

幸运的是,您拥有的基于 fetch() 构建的 then/catch 链返回了一个 Promise。所以你需要做的就是返回他们拥有的 Promise。就您而言,这很简单,只需在 return 调用之前放置一个 fetch()。所以它看起来像这样

    return fetch('http://www.omdbapi.com/?apikey=e255decd%20&s='+ movieName)
      // Other lines remain the same

大佬总结

以上是大佬教程为你收集整理的如何在 Dialogflow GUI 上使用 fetch 显示 API 数据全部内容,希望文章能够帮你解决如何在 Dialogflow GUI 上使用 fetch 显示 API 数据所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。