本文主要是介绍创建web workers,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
创建一个 Worker 脚本文件:首先,你需要创建一个 JavaScript 文件,这个文件将包含 Worker 线程将要执行的代码。
// worker.js
self.addEventListener('message', function(e) {const data = e.data;switch (data.cmd) {case 'start':self.postMessage('WORKER STARTED: ' + data.msg);break;case 'stop':self.postMessage('WORKER STOPPED: ' + data.msg);self.close(); // Terminates the worker.break;default:self.postMessage('Unknown command: ' + data.msg);}
}, false);
在主线程中创建 Worker 对象:使用 Worker
构造函数创建一个新的 Worker 对象,并指定 Worker 脚本文件的 URL。
// main.js
const myWorker = new Worker('worker.js');
发送和接收消息:使用 postMessage
方法发送消息到 Worker,使用 onmessage
事件监听器接收来自 Worker 的消息。
// 发送消息到 Worker
myWorker.postMessage({ cmd: 'start', msg: 'Hello, Worker!' });// 接收来自 Worker 的消息
myWorker.onmessage = function(e) {console.log('Message received from worker: ' + e.data);
};
结束 Worker:如果你想结束一个 Worker,可以调用 Worker 对象的 terminate
方法,或者在 Worker 内部调用 self.close()
。
// 在主线程中结束 Worker
myWorker.terminate();// 或在 Worker 脚本中结束自己
self.close();
完整的 HTML 示例
<!DOCTYPE html>
<html>
<head><title>Web Worker Example</title>
</head>
<body><button onclick="startWorker()">Start Worker</button><button onclick="stopWorker()">Stop Worker</button><script>let myWorker;function startWorker() {if (typeof(Worker) !== "undefined") {myWorker = new Worker("worker.js");myWorker.postMessage({ cmd: 'start', msg: 'Hello, Worker!' });myWorker.onmessage = function(event) {console.log('Message received from worker: ' + event.data);};} else {console.log("Sorry, your browser does not support Web Workers.");}}function stopWorker() {myWorker.postMessage({ cmd: 'stop', msg: 'Bye, Worker!' });myWorker.terminate();myWorker = undefined;}</script>
</body>
</html>
这样,你就成功创建了一个 Web Worker,并通过消息与其进行了交互。
这篇关于创建web workers的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!