- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Dialogflow 的内联编辑器实现来显示从 API 获取的动态数据。我尝试从 1 个 API 获取并且工作正常,现在我必须同时从 2 个 API 获取并在卡片中显示所有信息。
这是代码:
function GetProductAPI(agent) {
let prodnr1 =agent.parameters.prodnr1;
const webApiUrl = 'http://www.xxxxxxx.xx/api/products/';
// return axios.get(webApiUrl + prodnr1, { headers: {Authorization: `TOKEN zzzzzzzzzzzzz`} })
axios.all([
axios.get(webApiUrl + prodnr1, { headers: {Authorization: `TOKEN zzzzzzzzzzzzz`} }),
axios.get(webApiUrl + prodnr1 + '/images', { headers: {Authorization: `TOKEN zzzzzzzzzzzzz`} })
])
// .then(res => {
.then(axios.spread((user1, user2) => {
const launchData = user1.data;
const launchData2 = user2.data;
agent.add(`Product number is: ${launchData[0].ID} . Tile is : ${launchData[0].TITLE}, best price is : ${launchData[0].BEST_PRICE} , image url : ${launchData2[0].IMAGE_URL} `);
agent.add(new Card({
title: `${launchData[0].TITLE}`,
imageUrl: 'https://www.xxxx.xxx/cache/images/product/345345345334.jpg',
text: `${launchData[0].META_DESCRIPTION}`,
buttonText: 'Text from api',
buttonUrl: '${launchData[0].URL}'
})
);
}));
}
注释的代码我仅用于一次 API 调用并且运行良好,现在我尝试从 2 获取数据并在一个响应中使用数据却不起作用。您能帮我找出问题出在哪里吗?
最佳答案
您错过了 axios.all()
前面的 return
。工作代码是 return axios.all([...])
关于javascript - 如何在一个函数中从 2 个 api 获取数据并在对话框流卡履行中显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59211707/
实现的在线 shopify 文档显示了这个例子: POST /admin/orders/#{id}/fulfillments.json { "fulfillment": { "tra
我有检查数组中值的函数 const arr = [10,20,30]; const check = (needle) => { return new Promi
promise.each(function(obj){ obj.doIntensiveWork() .then(function(){ console.log("I A
我正在从 Protractor 切换到 Nightwatch.js,我在 Nightwatch 处理 promise 的方式上遇到了一些困难。 举个例子,我正在尝试计算满足给定条件的元素的数量。计数函
我正在尝试使用 DialogFlow 实现 Webhook 来访问我的应用程序,但每当我发出请求时,它都会返回: POST /webhook 500 INTERNAL SERVER ERROR 来自n
使用 BlueBird promise ,我尝试将 getCredentials 变成一个将作为 getCredentials.then(function() { do this and that }
我正在使用 Dialogflow 和 Actions on Google 开发一个应用程序,该应用程序需要在 Google Assistant 中发送每日生日通知。 我正在关注this documen
对于摩卡测试,我想断言 promise 最终会拒绝。 我不想使用 chai-as-promised。我更愿意只使用 Node 的标准断言模块,并且只使用标准 ES6 Promise。 我想出的最好的就
我想用其他 promise 来履行 promise 。重点是,我真的很想在第一个 promise 实现后立即访问(仍在等待中的)第二个promise。不幸的是,我似乎只能在两个 promise 都实现
我正在使用 Node.js 开发一个使用用户证书的项目。我需要以阻塞方式同步生成它们,但我使用的库(pem)只有异步函数(回调)。我尝试了多种方法来解决这个问题,但我的尝试都没有成功。我的代码如下所示
我试图表达如下内容: it("should use the 'text' mode", () => { let usedMockMode = false; let env = new
我是一名优秀的程序员,十分优秀!