跳至主要内容

工作线程

Worker 类表示一个 WebWorkerworker 事件在页面对象上发出,以指示工作线程的创建。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)

方法

evaluate

在 v1.9 之前添加 worker.evaluate

返回 表达式 的返回值。

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

如果传递给 worker.evaluate() 的函数返回一个非 可序列化 值,那么 worker.evaluate() 返回 undefined。Playwright 还支持传输一些无法通过 JSON 序列化的附加值:-0NaNInfinity-Infinity

用法

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

参数

  • expression str#

    要在浏览器上下文中评估的 JavaScript 表达式。如果表达式计算结果为函数,则该函数会自动调用。

  • arg EvaluationArgument (可选)#

    要传递给 表达式 的可选参数。

返回值


evaluate_handle

在 v1.9 之前添加 worker.evaluate_handle

表达式 的返回值作为 JSHandle 返回。

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 (可选)#

    要传递给 表达式 的可选参数。

返回值


属性

url

在 v1.9 之前添加 worker.url

用法

worker.url

返回值


事件

on("close")

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

当此专用 WebWorker 终止时发出。

用法

worker.on("close", handler)

事件数据