Pupeteer: send array of elementHandle to page.evaluate(Pupeteer:将elementHandle数组发送到page。评估)
本文介绍了Pupeteer:将elementHandle数组发送到page。评估的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
在Pupeteer中,我希望将任意数量的ElementHandle传递给数组中的方法EVALUATE:
const element1=await page.$(".element")
const element2=await page.$(".another-element")
await page.evaluate((elements)=>{
// do stuff with the array of elements
,[element1, element2]);
但是,由于ElementHandle不可序列化,因此出现以下错误:
TypeError: Converting circular structure to JSON
有没有办法实现这一点?
推荐答案
目前无法执行此操作。但是,您可以简单地借助扩散到参数来转换elemetHandle数组,然后使用睡觉运算符将它们重新收集到数组中:
const puppeteer = require('puppeteer');
const html = `
<html>
<body>
<div class="element">element 1</div>
<div class="element">element 2</div>
<div class="element">element 3</div>
</body>
</html>`;
(async () => {
const browser = await puppeteer.launch();
const page = await browser.newPage();
await page.goto(`data:text/html,${html}`);
const element1 = await page.$('.element:nth-child(1)');
const element2 = await page.$('.element:nth-child(2)');
const element3 = await page.$('.element:nth-child(3)');
const result = await page.evaluate((...elements) => {
// do stuff with the array of elements
return elements.map(element => element.textContent);
}, ...[element1, element2, element3]);
console.log(result);
await browser.close();
})();
这篇关于Pupeteer:将elementHandle数组发送到page。评估的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
编程基础网
本文标题为:Pupeteer:将elementHandle数组发送到page。评估
基础教程推荐
猜你喜欢
- HTML5 画布调整为父级 2022-01-01
- 使用 jQuery 在悬停时交换 DIV 类 2022-01-01
- 逻辑运算符 ||在 javascript 中,0 代表 Boolean false? 2022-01-01
- CORS:当凭据标志为真时,无法在 Access-Control-Allow-Origin 中使用通配符 2022-01-01
- 在 Javascript 中使用 Fetch API 上传文件并显示进度 2022-01-01
- 即使每次插入第一个输入的值不同,第二个输入仍显示相同的输入值 2022-01-01
- 最佳动态 JavaScript/JQuery 网格 2022-01-01
- 从快速中间件中排除路由 2022-01-01
- 当木偶师打开Chrome时,不能使用Chrome扩展 2022-01-01
- 带角度的选项卡:仅使用 $http 在单击时加载选项卡 2022-01-01
