- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在这里的措辞上有点困难,但要点是我使用返回一个对象的 Promise.race (如下所示)。大多数时候,至少有一些 promise 会崩溃,但这是故意的。这仅意味着未找到产品。为了避免 Promise 返回空白,我使用 try catch block 来启动一个新的 15 秒的定时 Promise。这可以防止 Promise 返回空白,让最快完成的函数将其对象返回到 Promise.race。在使用 Windows 10 在 NodeJS 10 中进行测试时,这似乎工作得很好,但是当我将其移植到运行 NodeJS 8 和 Ubuntu 18.04 的 Linux 服务器时,我遇到了一些奇怪的行为。 Promise.race 工作得很好,直到我在启动 NodeJS 应用程序后第一次测试该功能以来已经过去了 15 秒。当这 15 秒过去后,当我尝试与正常的 Promise 竞争时,它会立即返回定时的 Promise。
我首先要兑现这些 promise 。 (不确定这是否重要,但这是通过 HTTP 请求调用的)
let product = await Promise.race([
get_info_meny_joker(bar_code, "meny.no"),
get_info_meny_joker(bar_code, "joker.no"),
get_info_openfoodfacts(bar_code)
])
其中一个看起来像这样
async function get_info_meny_joker(bar_code, link) {
try {
let url = 'https://' + link + '/Sok/?query=' + bar_code
let browser = await puppeteer.launch({args: ['--no-sandbox']})
let page = await browser.newPage()
await page.goto(url, { waitUntil: 'networkidle2' })
let get_link = await page.evaluate(() => document.querySelector('.ws-product__title').getAttribute('href') )
let product_name = await page.evaluate(() => document.querySelector('.ws-product__title').innerText )
let product_amount = await page.evaluate(() => document.querySelector('.ws-product__subtitle').innerText )
let regex = "[0-9]+([gl]+|ml| [gl] | ml |kg| kg)"
let match = product_amount.match(regex)
match = match[0]
/*let regex_index = new RegExp("[A-Za-z]")
let index_match = regex_index.exec(match).index
match = match.splice(index_match, 0, " ")*/
product_amount = match
await page.goto('https://' + link + '/' + get_link, { waitUntil: 'networkidle2' })
const [first_product, second_product] = await page.$$('.ws-collapsable-block__heading');
await page.screenshot({ path: "x.png" })
second_product.click()
await page.screenshot({ path: "y.png" })
let img_url = await page.evaluate(() => document.querySelector('.lazyloaded').attributes[1].value)
// Get a list of all the nutrients found on the page
let nutrients_raw = await page.evaluate(() => {
let nutrients_raw = document.querySelector('.ws-nutritional-content').children
let nutrients = {}
let i = 0
for (let item of nutrients_raw) {
nutrients[i + ""] = item.innerText
i++
}
return nutrients
});
// Pretify the nutrients_raw to a nutrients object
let nutrients = {}
for (let i = 0; i < Object.size(nutrients_raw); i++) {
let s = nutrients_raw[i]
let type = s.slice(0, s.indexOf(':'))
let amount = s.slice(s.indexOf(':') + 2, s.length)
nutrients[type] = amount
}
return new Product(bar_code, product_name, product_amount, img_url, nutrients, link)
} catch (err) {
return await promise
}
}
定时 promise 看起来像这样
let promise = new Promise((resolve, reject) => {
let product = new Product()
product.name = "Could not be located"
setTimeout(() => resolve(product), 15000)
});
再说一遍,我可以 Promise.race 并且它工作得很好,直到我第一次与它们比赛以来已经过去了 15 秒。
(对这个问题来说并不重要,但我理解 Promise.race 函数是从堆栈中完全删除丢失的 Promise。奇怪的是它记得 15 秒已经过去了。)
最佳答案
您需要在此创建一个新的promise
:
let promise = new Promise((resolve, reject) => {
let product = new Product()
product.name = "Could not be located"
setTimeout(() => resolve(product), 15000)
});
每次您想使用它时。否则,当您开始使用计时器时,计时器已经运行了一段时间,并且它将在远小于 15000ms 的时间内触发,因为它已经运行了一段时间。事实上,如果自您创建 Promise 以来的时间超过 15000 毫秒,那么它就已经被解决了,当您在 .race()
中使用它时,竞赛将立即结束并解决这个问题 promise 。
Not important to the question, but I understood the Promise.race function as completely deleting the losing promises from the stack. Odd that it remembers 15 seconds has passed.
这是不正确的。 Promise.race()
不会删除任何内容。任何输掉比赛的 promise 都会继续下去。只是 Promise.race()
返回的 Promise 将在竞赛中的第一个 Promise 完成后立即解析。其他人继续顺利,并将按照自己的时间表完成。
您可能想要做的是将其放入一个函数中,并在您想要 15000ms promise 的任何时候调用该函数:
function timeoutPromise(t) {
return new Promise(resolve => {
let product = new Product();
product.name = "Could not be located";
setTimeout(() => resolve(product), t);
});
}
然后,只要您想使用新的超时 promise ,您只需调用此函数即可获取新的 promise ,而不是您正在使用的已保存的 promise
变量。
关于javascript - 定时 promise 解决在之前用时间解决一次后立即返回,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59038868/
我对开发领域有点陌生,我正在开发一个 Android 项目。我正在尝试使用手机相机闪光灯。我试图让它以重复的 Action 闪烁。下面是我的 .java 文件中的一个剪辑。 public vo
我正在制作一个 ios 应用程序,它是一种诗集。我想要的功能之一是定时“阅读”,因此一首诗中的单词出现的时间与我阅读时的时间相同。所以我有一个数组,里面有诗中的词,还有延迟。 现在我想遍历单词,在屏幕
这个问题在这里已经有了答案: Loop doesn't see value changed by other thread without a print statement (1 个回答) 关闭
我如何才能使用计时器?例如,我想显示某个文本 10 秒,然后我想在剩余时间内显示不同的文本。 谢谢 凯文 最佳答案 延迟操作的最简单方法是使用 NSObject 的 PerformSelector:w
我在这里的措辞上有点困难,但要点是我使用返回一个对象的 Promise.race (如下所示)。大多数时候,至少有一些 promise 会崩溃,但这是故意的。这仅意味着未找到产品。为了避免 Promi
我正在寻找定时 JDialog,它会在指定时间过后消失,并且找到的代码运行正常。 JFrame f = new JFrame(); final JDia
我试图让选择器在不同的时间轮换,我想我会尝试一个简单的 if/else 语句,让第一个选择器在 3 秒后轮换,接下来的选择器在 30 秒后轮换。然而,它只是每三秒旋转一次。如果我想出了如何完成这项工作
这个问题已经有答案了: How to implement a timer in c? (7 个回答) Creating a Timer in C (2 个回答) 已关闭 9 年前。 我需要根据用户输入
我有一个在我文档的 head 标签中调用的 javascript 文件,每隔 30 秒,我希望重新加载这个 javascript 文件。 我对此做了一些研究,似乎它在提取本地存储的文件副本或跨浏览器问
我想看看运行 bash 函数需要多长时间。在做了一些研究之后,我想出了这种使用子 shell 的方法: function test-function() { time ( rs
我正在使用 jQuery,并且我有一个 aAax 请求,如下所示; $.ajax({ type: 'POST', url: 'test.php',
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度的了解。包括尝试的解决方案、为什么它们不起作用以及预期结果
我想为系统的每笔交易制定一个程序任务,以预留15分钟的等待时间。如果超过15分钟,程序将改变状态/状态。如果状态在 15 分钟内发生变化,则结束任务。我可以应用更多更好的代码吗?比如Wait/Slee
我正在制作一个打字速度测试程序,它有一个循环需要运行 60 秒然后退出并显示结果。我读过其他关于为 C++ 程序计时的地方,但我的研究没有定论。该程序正在运行 (llbd),我希望有人有解决方案/更好
我试图在一个简单的游戏中每 0.5 - 2 秒随机创建一个障碍。我已经有了创建障碍的功能,但我无法为实例化计时。我试过研究这个,但我还没有想出任何相关的东西。你们能帮帮我吗? 最佳答案 您可以使用 p
我有以下测试,在运行特别长的 fib 断言时不会失败。 未正确失败的测试 #!/usr/env/bin python2.7 import unittest from fib import fib fr
我想知道这是否可行。有没有一种方法可以使用 PHP 每 24 小时更新一次行的值。为什么?我正在创建一个使用在线货币(称为 Yads)的 child 网站。 Row 的值是用户拥有的 Yad 数量。
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及预
有 Cron API 这样的东西吗? 我的意思是,是否有一种编程方式可以在不影响 Cron 的情况下添加/删除 Cron 作业? 最佳答案 UNIX cron 的 API 是文件系统。有一个用于安装/
1、SpringBoot:集成Swagger终极版 学习目标: 了解Swagger的概念及作用 掌握在项目中集成Swagger自动生成API文档 1.1、Sw
我是一名优秀的程序员,十分优秀!