Pass a function inside page.waitForFunction() with puppeteer(使用puppeteer在page.waitForFunction()内传递函数)
本文介绍了使用puppeteer在page.waitForFunction()内传递函数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
以下是我的代码:
function hasDataBeenRefreshed(pastAvgGain, currentAvgGain) {
if (pastAvgGain!== currentAvgGain) {
return true
} else {
return false
}
}
async function getInfos(paire, page) {
let pastAvgGain = C.AVG_GAIN.textContent
await page.click(paire)
let currentAvgGain = C.AVG_GAIN.textContent
await page.waitForFunction(hasDataBeenRefreshed(pastAvgGain, currentAvgGain))
...
}
但是如果我这样做,我会收到此错误:
Error: Evaluation failed: TypeError: true is not a function
有没有办法达到这样的效果?
推荐答案
page.waitForFunction()接受回调,现在您传入的是一个布尔值。要解决此问题,您可以执行以下操作:
await page.waitForFunction((pastAvgGain, currentAvgGain) => {
if (pastAvgGain!== currentAvgGain) {
return true
} else {
return false
}
} , {} , pastAvgGain, currentAvgGain )
https://github.com/puppeteer/puppeteer/blob/main/docs/api.md#pagewaitforfunctionpagefunction-options-args有关详细信息,请参阅文档
第三个参数是要传递给回调的参数
在您的评论之后:
await page.waitForFunction(() => {
return hasDataBeenRefreshed(pastAvgGain, currentAvgGain);
} )
这篇关于使用puppeteer在page.waitForFunction()内传递函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:使用puppeteer在page.waitForFunction()内传递函数


猜你喜欢
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- Flexslider 箭头未正确显示 2022-01-01
- 失败的 Canvas 360 jquery 插件 2022-01-01
- 400或500级别的HTTP响应 2022-01-01
- addEventListener 在 IE 11 中不起作用 2022-01-01
- Fetch API 如何获取响应体? 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01