跳到主要内容

Worker

Worker 类代表一个 WebWorkerworker 事件在 page 对象上发出,以表示 worker 的创建。当 worker 消失时,close 事件在 worker 对象上发出。

page.Worker += (_, worker) =>
{
Console.WriteLine($"Worker created: {worker.Url}");
worker.Close += (_, _) => Console.WriteLine($"Worker closed {worker.Url}");
};

Console.WriteLine("Current Workers:");
foreach(var pageWorker in page.Workers)
{
Console.WriteLine($"\tWorker: {pageWorker.Url}");
}

方法

EvaluateAsync

在 v1.9 之前添加 worker.EvaluateAsync

返回 expression 的返回值。

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

如果传递给 Worker.EvaluateAsync() 的函数返回一个非 Serializable 值,那么 Worker.EvaluateAsync() 返回 undefined。 Playwright 还支持传输一些额外的非 JSON 可序列化的值:-0NaNInfinity-Infinity

用法

await Worker.EvaluateAsync(expression, arg);

参数

  • expression string#

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

  • arg EvaluationArgument? (可选)#

    传递给 expression 的可选参数。

返回

  • [object]#

EvaluateHandleAsync

在 v1.9 之前添加 worker.EvaluateHandleAsync

JSHandle 形式返回 expression 的返回值。

Worker.EvaluateAsync()Worker.EvaluateHandleAsync() 之间的唯一区别是 Worker.EvaluateHandleAsync() 返回 JSHandle

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

用法

await Worker.EvaluateHandleAsync(expression, arg);

参数

  • expression string#

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

  • arg EvaluationArgument? (可选)#

    传递给 expression 的可选参数。

返回


Url

在 v1.9 之前添加 worker.Url

用法

Worker.Url

返回


事件

event Close

在 v1.9 之前添加 worker.event Close

当此专用 WebWorker 终止时发出。

用法

Worker.Close += async (_, worker) => {};

事件数据