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

标签 javascript reactjs webpack socket.io vite

我有一个迁移到 Vite 的 Create React 应用程序。
我用 socket.io-client .
除了捆绑器外,两个版本的应用程序完全相同(只需复制/粘贴)。
这是我的 websocket 连接

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

export function App() {
  useEffect(() => {
    io('http://my-server')
  })
}
在 webpack 版本中,我可以在网络选项卡中看到 socket.io 正在尝试连接。
但是在 vite 版本中它没有,它甚至没有抛出错误。
我怎样才能解决这个问题?这与仅支持 ESM 包而不支持 CommonJS 的 Vite 有什么关系吗?

最佳答案

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

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

关于javascript - 与 Vite 捆绑的 React 应用程序中的 Socket.IO 不起作用(与 Webpack 捆绑时会起作用),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69487625/

相关文章:

javascript - jQuery-增加显示的元素

javascript - 如何清除 Chrome 中特定选项卡上设置的间隔?

javascript - 在 react-big-calendar 中单击事件时添加弹出窗口?

javascript - Webpack 多个命名 block 在运行时忽略名称

javascript - 我无法使用 jquery 获取跨度的 ID

Javascript 不适用于彩色游戏

reactjs - 使用 React 创建上下文时找不到命名空间 'ctx' 错误 - typescript

javascript - 在 render 方法中使用 promise 渲染 React 组件

webpack - 注册服务人员时,Electron无法打开窗口

javascript - Webpack:仅使用特定配置加载 IE9 的脚本