微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

我如何在 chrome 扩展清单 V3的服务工作线程中包含一个 socket.io-client

如何解决我如何在 chrome 扩展清单 V3的服务工作线程中包含一个 socket.io-client

我从 cdn 复制了客户端 socket.io 脚本,然后使用了 importScript 但是当我运行它时会给出

ReferenceError: document is not defined
at JSONPPolling.doPoll (socketio.js:3683)
at JSONPPolling.poll (socketio.js:4369)
at JSONPPolling.doOpen (socketio.js:4313)
at JSONPPolling.open (socketio.js:3399)
at Socket.open (socketio.js:2796)
at new Socket (socketio.js:2725)
at socketio.js:2560
at Manager.open (socketio.js:470)
at new Manager (socketio.js:383)
at lookup (socketio.js:220)

我该如何解决这个问题,我的 service worker 文件代码

try {
importScripts('socket/socketio.js')


const socket = io("http://localhost:8080")


socket.on('connect',() => {
    console.log(socket.id)
})


} catch (e) {
console.log(e)
}

解决方法

您可以使用 webpack 将 socket.io 客户端绑定到后台 Service Worker。

为了避免 wOxxOm 提到的 document 问题,您可以使用 jsonp: false 选项。

const socket = io('URL',{
  jsonp: false,});

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。