- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试调用 Trip Advisor API 并使用异步/等待函数返回一些数据。
async/await 函数定义在名为 req.js 的文件中,代码如下:
const findRest = async (reviews, closed) => {
const respond = await fetch(
"https://tripadvisor1.p.rapidapi.com/restaurants/list-by-latlng?limit=30¤cy=EUR&distance=2&lunit=km&lang=en_US&latitude=53.3498&longitude=-6.2603",
{
method: "GET",
headers: {
"x-rapidapi-host": "tripadvisor1.p.rapidapi.com",
"x-rapidapi-key": "x-rapidapi-key"
}
}
);
if (respond.status === 200) {
let data = await respond.json();
let newData = await data.data;
let data1 = await newData.filter(
review => parseInt(review.num_reviews) >= reviews
);
let data2 = await data1.filter(close => close.is_closed == closed);
return data2;
} else {
throw new Error("Could not provide results within specified parameters");
}
};
当事件监听器通过单击小窗体中的按钮触发时将调用它。此代码位于名为 app.js 的文件中,如下所示:
document.getElementById("subButton").addEventListener("click", function(e) {
const userReviews = parseInt(document.querySelector(".userRev").value);
const userClose = document.querySelector(".userClose").value;
e.preventDefault();
console.log("click");
console.log(e.target.id);
findRest(userReviews, userClose)
.then(data =>
data.forEach(element =>
console.log(
`${element.name} matches your search criterea and is located at ${element.address}
To make a booking, please call ${element.phone}`
)
)
)
.catch(err => console.log(err));
});
此处供引用的是 HTML:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width,initial-scale=1" />
<title>API Tester</title>
<meta name="author" content="Phil My Glass" />
<meta
name="description"
content="An app to help me practice my API calling"
/>
</head>
<body>
<header>
<h1>What Restaurant?</h1>
</header>
<main>
<form id="form">
<input id="userRev" class="userRev" /><br />
<input id="userClose" class="userClose" />
<button id="subButton" class="subButton" type="submit">Find!</button>
</form>
</main>
</body>
<script src="req.js" type="text/Javascript"></script>
<script src="app.js" type="text/Javascript"></script>
</html>
当我在 app.js 文件中但在事件监听器外部运行 findRest 函数并将参数作为静态数据传递时,它只执行查找并将所有请求的数据打印到控制台。一旦我尝试在事件监听器中运行它,就什么也没有发生。没有返回的数据打印,没有错误,这让我很困惑。
就像我说的,它在事件监听器之外工作正常,但我已经尝试将 forEach 更改为映射,但仍然没有返回任何内容。有人可以帮忙吗!
最佳答案
从评论和您的回复来看:没有任何事情发生的原因是因为数据是一个空数组。Array.forEach(callback)
仅在数组包含元素时执行回调。
它可能为空的原因是 restaurant.is_closed
的过滤器可能需要一个 bool 值,而您传入的是一个字符串(输入元素的值是一个字符串)。
最好使用复选框来查看它是否被选中。否则,您必须查看字符串输入是否匹配“true”或“false”。
findRest
包含不必要的等待。您应该将其定义为
async function findRest(reviews, closed) {
const response = await fetch(
"https://tripadvisor1.p.rapidapi.com/restaurants/list-by-latlng?limit=30¤cy=EUR&distance=2&lunit=km&lang=en_US&latitude=53.3498&longitude=-6.2603",
{
method: "GET",
headers: {
"x-rapidapi-host": "tripadvisor1.p.rapidapi.com",
"x-rapidapi-key": "x-rapidapi-key"
}
}
);
if (response.status === 200) {
// The only async call is casting the response to a JavaScript object
const json = await response.json();
console.log(json);
const data = json.data;
// Filtering the array is not async
return data.filter((restaurant) => {
// Adding some additional debugs to prove my hypothesis right
const hasEnoughReviews = restaurant.num_review >= reviews;
const isClosed = restaurant.is_closed === closed;
console.log(`review debug: ${typeof restaurant.num_review}, ${typeof reviews} -> output: ${hasEnoughReviews}`);
console.log(`closed debug: ${typeof restaurant.is_closed}, ${typeof closed} -> output: ${isClosed}`)
return hasEnoughReviews && isClosed
})
} else {
throw new Error("Could not provide results within specified parameters");
}
}
您还可以在 eventListener 回调中使用 async/await,创建更简洁的代码
document.getElementById("subButton").addEventListener("click", async (e) => {
const userReviews = parseInt(document.querySelector(".userRev").value);
// Judging by the filter in the findRest, this should be a boolean?
const userClose = document.querySelector(".userClose").value;
e.preventDefault();
console.log("click");
console.log(e.target.id);
try {
const restaurants = await findRest(userReviews, userClose);
// I think your issue is that restaurants is an empty array
console.log(restaurants)
restaurants.forEach(restaurant => {
console.log(`${restaurant.name} matches your search criterea and is located at ${restaurant.address}
To make a booking, please call ${restaurant.phone}`)
})
} catch (err) {
console.log(err)
}
});
关于javascript - 异步等待函数未在事件监听器中执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59390307/
我找到了 this excellent question and answer它以 x/y(加上 center x/y 和 degrees/radians)开始并计算旋转- 到 x'/y'。这个计算很
全部: 我已经创建了一个 Windows 窗体和一个按钮。在另一个线程中,我试图更改按钮的文本,但它崩溃了;但是如果我尝试更改按钮的颜色,它肯定会成功。我认为如果您更改任何 Windows 窗体控件属
本网站的另一个问题已证实,C 中没有缩写的字面后缀,并且可以执行以下操作: short Number = (short)1; 但是转换它和不这样做有什么区别: short Number = 1; 您使
我有下表: ID (int) EMAIL (varchar(50)) CAMPAIGNID (int) isSubscribe (bit) isActionByUser (bit) 此表存储了用户对事
也就是说,无需触发Javascript事件即可改变的属性,如何保留我手动选中或取消选中的复选框的状态,然后复制到另一个地方? 运行下面的代码片段并选中或取消选中其中的一些,然后点击“复制”: $('#
我在网上找到的所有关于递增指针导致段错误的示例都涉及指针的取消引用 - 如果我只想递增它(例如在 for 循环的末尾)并且我不在乎它是否最终进入无效内存,因为我不会再使用它。例如,在这个程序中,每次迭
我有一个 Spring MVC REST 服务,它使用 XStream 将消息与 XML 相互转换。 有什么方法可以将请求和响应中的 xml(即正文)打印到普通的 log4j 记录器? 在 Contr
做我的任务有一个很大的挑战,那就是做相互依赖的任务我在这张照片中说的。假设我们有两个任务 A 和 B,执行子任务 A1、A2 和 B1、B2,假设任务 B 依赖于 A。 要理想地执行任务 B,您应该执
通过阅读该网站上的几个答案,我了解到 CoInitialize(Ex) should be called by the creator of a thread 。然后,在该线程中运行的任何代码都可以使
这个问题已经困扰我一段时间了。我以前从未真正使用过 ListViews,也没有使用过 FirebaseListAdapters。我想做的就是通过显示 id 和用户位置来启动列表的基础,但由于某种原因,
我很难解释这两个(看似简单)句子的含义: “受检异常由编译器在编译时检查” 这是什么意思?编译器检查是否捕获了所有已检查的异常(在代码中抛出)? “未经检查的异常在运行时检查,而不是编译时” 这句话中
我有一个包含排除子字符串的文本文件,我想迭代该文件以检查并返回不带排除子字符串的输入项。 这里我使用 python 2.4,因此下面的代码可以实现此目的,因为 with open 和 any 不起作用
Spring 的缓存框架能否了解请求上下文的身份验证状态,或者更容易推出自己的缓存解决方案? 最佳答案 尽管我发现这个用例 super 奇怪,但您可以为几乎任何与 SpEL 配合使用的内容设置缓存条件
我有以下函数模板: template HeldAs* duplicate(MostDerived *original, HeldAs *held) { // error checking omi
如果我的应用程序具有设备管理员/设备所有者权限(未获得 root 权限),我如何才能从我的应用程序中终止(或阻止启动)另一个应用程序? 最佳答案 设备所有者可以阻止应用程序: DevicePolicy
非常简单的问题,但我似乎无法让它正常工作。 我有一个组件,其中有一些 XSLT(用于导航)。它通过 XSLT TBB 使用 XSLT Mediator 发布。 发布后
我正在将一个对象拖动到一个可拖放的对象内,该对象也是可拖动的。放置对象后,它会嵌套在可放置对象内。同样,如果我将对象拖到可放置的外部,它就不再嵌套。 但是,如果我经常拖入和拖出可放置对象,则可拖动对象
我正在尝试为按钮和弹出窗口等多个指令实现“取消选择”功能。也就是说,我希望当用户单击不属于指令模板一部分的元素时触发我的函数。目前,我正在使用以下 JQuery 代码: $('body').click
我从 this question 得到了下面的代码,该脚本用于在 Google tasks 上更改 iframe[src="about:blank"] 内的 CSS使用 Chrome 扩展 Tempe
我有一些 @Mock 对象,但没有指定在该对象上调用方法的返回值。该方法返回 int (不是 Integer)。我很惊讶地发现 Mockito 没有抛出 NPE 并返回 0。这是预期的行为吗? 例如:
我是一名优秀的程序员,十分优秀!