postMessage

postmessage方法怎么使用

小亿
133
2023-07-06 16:25:27
栏目: 编程语言

postMessage方法是用于在Web Worker和主线程之间进行通信的方法。它接受两个参数:message和transferList。

在主线程中,可以通过worker.postMessage(message, transferList)方法向Web Worker发送消息。

在Web Worker中,可以通过self.postMessage(message, transferList)方法向主线程发送消息。

示例:

在主线程中向Web Worker发送消息:

var worker = new Worker('worker.js');
worker.postMessage('Hello');
// 或者发送带有资源的消息
var buffer = new ArrayBuffer(16);
worker.postMessage({ data: buffer }, [buffer]);

在Web Worker中向主线程发送消息:

self.postMessage('Hello');
// 或者发送带有资源的消息
var buffer = new ArrayBuffer(16);
self.postMessage({ data: buffer }, [buffer]);

在主线程中监听Web Worker发送的消息:

var worker = new Worker('worker.js');
worker.onmessage = function(event) {
console.log('Received message from worker:', event.data);
};

在Web Worker中监听主线程发送的消息:

self.onmessage = function(event) {
console.log('Received message from main thread:', event.data);
};

0
看了该问题的人还看了