跳到主要内容

Worker

Worker 类表示一个 WebWorker。当创建 worker 时,会在 page 对象上触发 worker 事件。当 worker 被销毁时,会在 worker 对象上触发 close 事件。

def handle_worker(worker):
print("worker created: " + worker.url) # worker 被创建
worker.on("close", lambda: print("worker destroyed: " + worker.url)) # worker 被销毁

page.on('worker', handle_worker)

print("current workers:") # 当前的 worker
for worker in page.workers:
print(" " + worker.url)

方法

evaluate

v1.9 之前添加 worker.evaluate

返回 expression 的返回值。

如果传递给 worker.evaluate() 的函数返回一个 Promise,那么 worker.evaluate() 会等待该 promise 解析并返回其值。

如果传递给 worker.evaluate() 的函数返回一个非 Serializable 的值,则 worker.evaluate() 返回 undefined。Playwright 还支持传递一些 JSON 无法序列化的额外值:-0NaNInfinity-Infinity

用法

worker.evaluate(expression)
worker.evaluate(expression, **kwargs)

参数

  • expression str#

    要在浏览器上下文中执行的 JavaScript 表达式。如果表达式的结果是一个函数,则该函数会被自动调用。

  • arg EvaluationArgument (可选)#

    传递给 expression 的可选参数。

返回值


evaluate_handle

v1.9 之前添加 worker.evaluate_handle

JSHandle 的形式返回 expression 的返回值。

worker.evaluate()worker.evaluate_handle() 唯一的区别是 worker.evaluate_handle() 返回 JSHandle

如果传递给 worker.evaluate_handle() 的函数返回一个 Promise,那么 worker.evaluate_handle() 会等待该 promise 解析并返回其值。

用法

worker.evaluate_handle(expression)
worker.evaluate_handle(expression, **kwargs)

参数

  • expression str#

    要在浏览器上下文中执行的 JavaScript 表达式。如果表达式的结果是一个函数,则该函数会被自动调用。

  • arg EvaluationArgument (可选)#

    传递给 expression 的可选参数。

返回值


属性

url

v1.9 之前添加 worker.url

用法

worker.url

返回值


事件

on("close")

v1.9 之前添加 worker.on("close")

当该专用 WebWorker 被终止时触发。

用法

worker.on("close", handler)

事件数据