Worker
Worker 类代表一个 WebWorker。当创建 worker 时,会在 page 对象上触发 worker
事件。当 worker 终止时,会在 worker 对象上触发 close
事件。
page.on('worker', worker => {
console.log('Worker created: ' + worker.url());
worker.on('close', worker => console.log('Worker destroyed: ' + worker.url()));
});
console.log('Current workers:');
for (const worker of page.workers())
console.log(' ' + worker.url());
方法
evaluate
在 v1.9 之前添加返回 pageFunction 的返回值。
如果传递给 worker.evaluate() 的函数返回一个 Promise,则 worker.evaluate() 将等待该 Promise 解析并返回其值。
如果传递给 worker.evaluate() 的函数返回一个不可 序列化 的值,则 worker.evaluate() 返回 undefined
。Playwright 还支持传输一些 JSON 不可序列化的额外值:-0
、NaN
、Infinity
、-Infinity
。
用法
await worker.evaluate(pageFunction);
await worker.evaluate(pageFunction, arg);
参数
-
pageFunction
function | string#要在 worker 上下文中评估的函数。
-
arg
EvaluationArgument (可选)#传递给 pageFunction 的可选参数。
返回值
evaluateHandle
在 v1.9 之前添加将 pageFunction 的返回值作为 JSHandle 返回。
worker.evaluate() 和 worker.evaluateHandle() 之间的唯一区别在于 worker.evaluateHandle() 返回 JSHandle。
如果传递给 worker.evaluateHandle() 的函数返回一个 Promise,则 worker.evaluateHandle() 将等待该 Promise 解析并返回其值。
用法
await worker.evaluateHandle(pageFunction);
await worker.evaluateHandle(pageFunction, arg);
参数
-
pageFunction
function | string#要在 worker 上下文中评估的函数。
-
arg
EvaluationArgument (可选)#传递给 pageFunction 的可选参数。
返回值
url
在 v1.9 之前添加用法
worker.url();
返回值
事件
on('close')
在 v1.9 之前添加当此专用 WebWorker 终止时触发。
用法
worker.on('close', data => {});
事件数据