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)
方法
evaluate
在 v1.9 之前添加返回 expression 的返回值。
如果传递给 worker.evaluate() 的函数返回一个 Promise,那么 worker.evaluate() 将等待 Promise resolve 并返回其值。
如果传递给 worker.evaluate() 的函数返回一个非 Serializable 值,那么 worker.evaluate() 返回 undefined
。Playwright 还支持传输一些 JSON
无法序列化的其他值:-0
、NaN
、Infinity
、-Infinity
。
用法
worker.evaluate(expression)
worker.evaluate(expression, **kwargs)
参数
-
要在浏览器上下文中计算的 JavaScript 表达式。如果表达式计算结果为函数,则会自动调用该函数。
-
arg
EvaluationArgument (可选)#传递给 expression 的可选参数。
返回值
evaluate_handle
在 v1.9 之前添加以 JSHandle 形式返回 expression 的返回值。
worker.evaluate() 和 worker.evaluate_handle() 之间的唯一区别是 worker.evaluate_handle() 返回 JSHandle。
如果传递给 worker.evaluate_handle() 的函数返回一个 Promise,那么 worker.evaluate_handle() 将等待 Promise resolve 并返回其值。
用法
worker.evaluate_handle(expression)
worker.evaluate_handle(expression, **kwargs)
参数
-
要在浏览器上下文中计算的 JavaScript 表达式。如果表达式计算结果为函数,则会自动调用该函数。
-
arg
EvaluationArgument (可选)#传递给 expression 的可选参数。
返回值
属性
url
在 v1.9 之前添加用法
worker.url
返回值
事件
on("close")
在 v1.9 之前添加当这个专用的 WebWorker 终止时发出。
用法
worker.on("close", handler)
事件数据