SharedWorker 是一种在多个标签页、iframe 或者浏览器实例之间共享的后台线程,例如每个页面都有websocket请求,那么相同的页面多tab 打开或iframe嵌套会产生多次websocket请求,如何websocket请求放到shareworker中,接受和发送都由shareworker来中转,那么任意个同域名页面只需要一次websocket请求就好了。
SharedWorker 允许不同的脚本运行在同一个共享的工作线程上,这样它们就能够共享同样的数据连接或者进行通信。
而 ServiceWorker 主要用于实现离线体验、消息推送和后台同步等功能。ServiceWorker 充当了 web 应用程序、浏览器与网络之间的代理服务器。它允许网站拦截和处理网络请求,包括根据网络可用性动态地加载离线页面。
不同点主要包括:
生命周期:ServiceWorker 是长生命周期的,即使标签页关闭了也可存在,直到被明确地终止。而 SharedWorker 仅在至少一个标签页使其处于活动状态时才存在。
用途:SharedWorker 适合做数据共享和脚本通讯,而 ServiceWorker 更适合做资源缓存和离线内容提供。
作用范围:ServiceWorker 可以控制整个域下的多个页面,它与具体页面独立;SharedWorker 则是由创建它的同源页面共同控制。
通信方式:SharedWorker 与页面间的通信依赖于 postMessage 接口;ServiceWorker 的通信则依赖于监听和触发事件。
以下是一个简单的 SharedWorker 示例代码:
SharedWorker 的 JavaScript 文件 testworker.js:
const ports = [];
self.onconnect = (e) => {
const port = e.ports[0];
ports.push(port);
port.onmessage = (e) => {
console.log(e.data);
sendMessage(e.data);
};
};
// 发送消息
function sendMessage(message) {
ports.forEach((port) => {
port.postMessage(message);
});
}
然后在两个不同的标签页或脚本中使用这个 testworker,例如 page1.html 和 page2.html:
在 page1.html: <script>
var myWorker = new SharedWorker('/asset/testworker.js');
// 监听 worker 的消息
myWorker.port.addEventListener('message', function(e) {
if (e.data instanceof Array) {
if (e.data[0] === 'result') {
console.log('Result:', e.data[1]);
}
} else {
console.log('Message from worker:', e.data);
}
}, false);
// 监听 error 事件
myWorker.port.addEventListener('error', function(e) {
console.error('Error:', e);
}, false);
// 启动 worker 并发送消息
myWorker.port.start();
myWorker.port.postMessage('Hello from page1');
</script>在 page2.html: <script>
var myWorker = new SharedWorker('/asset/testworker.js');
// 监听 worker 的消息
myWorker.port.addEventListener('message', function(e) {
if (e.data instanceof Array) {
if (e.data[0] === 'result') {
console.log('Result:', e.data[1]);
}
} else {
console.log('Message from worker:', e.data);
}
}, false);
// 监听 error 事件
myWorker.port.addEventListener('error', function(e) {
console.error('Error:', e);
}, false);
// 启动 worker 并发送消息
myWorker.port.start();
myWorker.port.postMessage('Hello from page2');
</script>在这个例子中,无论是 page1.html 或 page2.html 发送信息到 testworker.js,都将通过 SharedWorker 中的端口接收和发送消息。SharedWorker 将会接收消息并且群发到所有页面。
那么如何查看sharedworker中的console.log输出信息呢,浏览器输入:chrome://inspect/#workers

网友回复


