与 Vite 捆绑的 React 应用程序中的 Socket.IO 不起作用(与 Webpack 捆绑时可以)

Two*_*ses 7 javascript socket.io reactjs webpack vite

我有一个 Create React 应用程序,已迁移到 Vite。
我用socket.io-client

除了捆绑程序之外,该应用程序的两个版本完全相同(只需复制/粘贴)。

这是我的 websocket 连接

import { io } from 'socket.io-client'

export function App() {
  useEffect(() => {
    io('http://my-server')
  })
}
Run Code Online (Sandbox Code Playgroud)

在 webpack 版本中,我可以在网络选项卡中看到 socket.io 正在尝试连接。

但在 vite 版本中却没有,甚至不会抛出错误。

我怎样才能解决这个问题?这和Vite只支持ESM包而不支持CommonJS有什么关系吗?

Two*_*ses 3

最终我通过transports在连接中指定一个属性解决了这个问题,如下所示:

io('http://my-server', {
    transports: ['websocket'], // Required when using Vite      
})
Run Code Online (Sandbox Code Playgroud)