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

page.evaluate(pageFunction, ...args)

  • pageFunction <[function]|[string]> 要在頁面實例上下文中執行的方法
  • ...args <...[Serializable]|[JSHandle]> 要傳給 pageFunction 的參數
  • 返回: <[Promise]<[Serializable]>> pageFunction執行的結果

若是pageFunction返回的是[Promise],page.evaluate將等待promise完成,並返回其返回值。html

若是pageFunction返回的是不能序列化的值,將返回undefinedgit

pageFunction傳參數示例:github

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:api

const bodyHandle = await page.$('body');
const html = await page.evaluate(body => body.innerHTML, bodyHandle);
await bodyHandle.dispose();
相關文章
相關標籤/搜索