page.evaluate(pageFunction, ...args)详解

page.evaluate(pageFunction, ...args)详解,第1张

概述page.evaluate(pageFunction, ...args) pageFunction <[function]|[string]> 要在页面实例上下文中执行的方法 ...args <...[Serializable]|[JSHandle]> 要传给 pageFunction 的参数 返回: <[Promise]<[Serializable]>> pageFunction执行的结果 如果 page.evaluate(pageFunction,...args) pageFunction <[function]|[string]> 要在页面实例上下文中执行的方法 ...args <...[Serializable]|[JsHandle]> 要传给 pageFunction 的参数 返回: <[Promise]<[Serializable]>> pageFunction执行的结果

如果pageFunction返回的是[Promise],page.evaluate将等待promise完成,并返回其返回值。

如果pageFunction返回的是不能序列化的值,将返回undefined

pageFunction传参数示例:

const result = await page.evaluate(x => {  return Promise.resolve(8 * x);},7); // (译者注: 7 可以是你自己代码里任意方式得到的值)console.log(result); // 输出 "56"
也可以传一个字符串:
console.log(await page.evaluate(‘1 + 2‘)); // 输出 "3"const x = 10;console.log(await page.evaluate(`1 + ${x}`)); // 输出 "11"

[ElementHandle] 实例 可以作为参数传给 page.evaluate:

const bodyHandle = await page.$(‘body‘);const HTML = await page.evaluate(body => body.INNERHTML,bodyHandle);await bodyHandle.dispose();
总结

以上是内存溢出为你收集整理的page.evaluate(pageFunction, ...args)详解全部内容,希望文章能够帮你解决page.evaluate(pageFunction, ...args)详解所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1234657.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存