Worker
Worker
类表示一个 WebWorker。页面对象上会触发 worker
事件,以表明创建了一个 worker。当 worker 消失时,会在 worker 对象上触发 close
事件。
page.onWorker(worker -> {
System.out.println("Worker created: " + worker.url());
worker.onClose(worker1 -> System.out.println("Worker destroyed: " + worker1.url()));
});
System.out.println("Current workers:");
for (Worker worker : page.workers())
System.out.println(" " + worker.url());
方法
evaluate
v1.9 之前添加返回 expression 的返回值。
如果传递给 Worker.evaluate() 的函数返回一个 Promise,那么 Worker.evaluate() 将等待该 Promise 解决,并返回其值。
如果传递给 Worker.evaluate() 的函数返回一个不可 [序列化] 的值,那么 Worker.evaluate() 将返回 undefined
。Playwright 还支持传输一些 JSON
无法序列化的额外值:-0
、NaN
、Infinity
、-Infinity
。
用法
Worker.evaluate(expression);
Worker.evaluate(expression, arg);
参数
-
要在浏览器上下文中求值的 JavaScript 表达式。如果该表达式求值为一个函数,则会自动调用该函数。
-
arg
EvaluationArgument(可选)#传递给 expression 的可选参数。
返回值
evaluateHandle
在 v1.9 之前添加以 JSHandle 的形式返回 expression 的返回值。
Worker.evaluate() 和 Worker.evaluateHandle() 之间的唯一区别在于,Worker.evaluateHandle() 返回 JSHandle。
如果传递给 Worker.evaluateHandle() 的函数返回一个 Promise,那么 Worker.evaluateHandle() 将等待该 Promise 解决并返回其值。
用法
Worker.evaluateHandle(expression);
Worker.evaluateHandle(expression, arg);
参数
-
要在浏览器上下文中计算的 JavaScript 表达式。如果表达式计算结果为一个函数,则该函数会自动调用。
-
arg
EvaluationArgument(可选)#传递给 expression 的可选参数。
返回值
url
在 v1.9 之前添加用法
Worker.url();
返回值
waitForClose
添加于:v1.10执行操作并等待 Worker
关闭。
用法
Worker.waitForClose(callback);
Worker.waitForClose(callback, options);
参数
-
options
Worker.WaitForCloseOptions
(可选)-
setTimeout
double(可选)新增于:v1.9#最大等待时间(毫秒)。默认为
30000
(30 秒)。传入0
可禁用超时。默认值可通过 BrowserContext.setDefaultTimeout() 更改。
-
-
执行触发该事件的操作的回调函数。
返回值
事件
onClose(handler)
在 v1.9 之前新增当此专用 WebWorker 终止时触发。
用法
Worker.onClose(handler)