Worker
Worker 类表示页面中的 WebWorker。页面对象会在创建 Worker 时触发 worker 事件;当 Worker 结束时,会在 Worker 对象上触发 close 事件。
def handle_worker(worker):
print("worker created: " + worker.url)
worker.on("close", lambda: print("worker destroyed: " + worker.url))
page.on('worker', handle_worker)
print("current workers:")
for worker in page.workers:
print(" " + worker.url)
- worker.on("close")
- worker.evaluate(expression, **kwargs)
- worker.evaluate_handle(expression, **kwargs)
- worker.url
worker.on("close")
Added in: v1.8- type: <Worker>
当该专用 WebWorker 被终止时触发。
worker.evaluate(expression, **kwargs)
Added in: v1.8expression<str> 在浏览器上下文中执行的 JavaScript 表达式。如果表达式求值得到函数,会自动调用该函数。#arg<EvaluationArgument> 传递给expression的可选参数。#- 返回值: <Serializable>#
返回 expression 的执行结果。
如果传给 worker.evaluate(expression, **kwargs) 的函数返回 Promise,该方法会等待 Promise 解析后返回其值。
如果函数返回的值不是 Serializable,worker.evaluate(expression, **kwargs) 会返回 undefined。Playwright 还支持传输 JSON 无法序列化的额外值:-0、NaN、Infinity、-Infinity。
worker.evaluate_handle(expression, **kwargs)
Added in: v1.8expression<str> 在浏览器上下文中执行的 JavaScript 表达式。如果表达式求值得到函数,会自动调用该函数。#arg<EvaluationArgument> 传递给expression的可选参数。#- 返回值: <JSHandle>#
以 JSHandle 形式返回 expression 的执行结果。
worker.evaluate(expression, **kwargs) 与 worker.evaluate_handle(expression, **kwargs) 唯一的区别在于后者返回 JSHandle。
如果传给 worker.evaluate_handle(expression, **kwargs) 的函数返回 Promise,该方法会等待 Promise 解析后返回其值。
worker.url
Added in: v1.8返回该 Worker 的 URL。