💥解决Vue开发环境报http://localhost:8080/sockjs-node/info...错误💥

vue的小伙伴看见下面这个图眼熟不?不要告诉我你没见过!

我的项目里为什么会有这个?

package.json

node_modules

sockjs-node 是一个JavaScript库,提供跨浏览器JavaScript的API,创建了一个低延迟、全双工的浏览器和web服务器之间通信通道。在项目运行之后,会一直调用这个接口。SockJS是一个JavaScript库(用于浏览器),提供类似于WevSocket的对象。其作用就是开发环境下,保证我们在改完代码重新编译之后,能够通知浏览器重新加载变更结果。这里理解为这个库使用来让本地与浏览器之间的热模块更新通信的。

当我们通过vue/cli5以下版本搭建Vue项目的时候,安装依赖的时候,这个包即使不在package.json里也会装上,看上面2个图。所以当我们启动项目之后,在Network中会自动持续发送 /sockjs-node/info?t=<当前时间戳> 请求

为什么会报错?

前面说了SockJS库是让本地与浏览器之间的热模块更新通信的,如果两个地址对接不上了,可能就会报该错误,再结合这个包的源码来排查一下,可以看到包默认的地址是localhost:80,但是一般本地默认启动是localhost:8080或者我这样的自定义端口,两边地址对不上了。

怎么解决

网上找了几种解决方案

  • 将源码里面的地址改为本地环境 (如果有需求重新执行npm install的时候又得改一次 ❌)
  • 将报错的方法注释掉(首先会有上面那个问题,其次浏览器热更新也失效了 ❌)
  • 查看官网配置文档,是有这个配置项的,改为自己的地址即可 ✅

重新启动项目,控制台再也没有红色的报错啦 🌈🌈🌈

相关推荐
天天向上10241 小时前
Vue 配置打包后可编辑的变量
前端·javascript·vue.js
芬兰y2 小时前
VUE 带有搜索功能的穿梭框(简单demo)
前端·javascript·vue.js
好果不榨汁2 小时前
qiankun 路由选择不同模式如何书写不同的配置
前端·vue.js
写不出来就跑路2 小时前
基于 Vue 3 的智能聊天界面实现:从 UI 到流式响应全解析
前端·vue.js·ui
1undefined23 小时前
element中的Table改造成虚拟列表,并封装成hooks
前端·javascript·vue.js
paopaokaka_luck4 小时前
基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
java·数据库·vue.js·spring boot·后端·spring·小程序
用户3802258598244 小时前
vue3源码解析:依赖收集
前端·vue.js
wzyoung5 小时前
element-ui让el-form绑定的深层对象也能通过内置的resetFields方法重置
前端·javascript·vue.js
枣把儿6 小时前
Vercel 收购 NuxtLabs!Nuxt UI Pro 即将免费!
前端·vue.js·nuxt.js
paopaokaka_luck6 小时前
智能推荐社交分享小程序(websocket即时通讯、协同过滤算法、时间衰减因子模型、热度得分算法)
数据库·vue.js·spring boot·后端·websocket·小程序