怎么用javascript操作websocket_javascript如何实现实时通信
发布时间 - 2026-01-06 00:00:00 点击率:次WebSocket连接必须用new WebSocket()创建,协议限于ws/wss,需等待onopen后发送消息,binaryType需设为arraybuffer处理二进制数据,断线重连需指数退避并限制次数。
WebSocket 连接必须用 new WebSocket() 创建,不能用 fetch 或 XMLHttpRequest
WebSocket 是独立于 HTTP 的全双工协议,浏览器不支持用传统请求方式“发起”连接。你看到的 ws:// 或 wss:// 地址,只能传给 WebSocket 构造函数——其他任何 API 都无法建立真正的 WebSocket 连接。
-
fetch('ws://example.com')会直接报错:TypeError: Invalid URL -
new WebSocket('http://...')会失败,协议必须是ws或wss - 连接过程不可取消,没有类似
AbortController的机制 - 首次握手依赖 HTTP Upgrade,所以服务端必须明确支持 WebSocket 协议(如 Node.js 的
ws、socket.io或 Nginx 正确配置Upgrade头)
监听 onmessage 前必须确保 readyState === 1,否则消息会丢失
WebSocket 初始化后处于 CONNECTING(值为 0),此时调用 send() 会抛出异常,而 onmessage 回调即使已注册,也不会触发——因为连接尚未就绪。很多实时功能失效,根源就是没等连接完成就开始发/收数据。
- 正确做法:在
onopen回调里开始发送初始化消息或启用 UI 交互 - 错误写法:
const ws = new WebSocket('wss://api.example.com'); ws.onmessage = e => console.log(e.data); // ✅ 注册了 ws.send('hello'); // ❌ 此时 readyState 很可能还是 0,报错 - 安全判断:
if (ws.readyState === WebSocket.OPEN) { ws.send(data); } else { console.warn('WebSocket not ready, current state:', ws.readyState); }
服务端推送的二进制数据默认转成 Blob,需手动设 binaryType = 'arraybuffer'
WebSocket 收到二进制帧(如图片、音频、Protobuf 序列化数据)时,浏览器默认把 event.data 当作 Blob 处理。如果后端发的是 ArrayBuffer,前端却按 Blob 解析,就会卡在 blob.arrayBuffer() 异步流程里,破坏实时性。
- 立即生效的设置:
const ws = new WebSocket('wss://api.example.com'); ws.binaryType = 'arraybuffer'; // 必须在 onopen 前或连接建立后立刻设 ws.onmessage = e => { if (e.data instanceof ArrayBuffer) { const view = new Uint8Array(e.data); console.log('Received raw bytes:', view); } }; - 不设
binaryType时,e.data是Blob,必须用e.data.arrayBuffer().then(...),引入 Promise 延迟 - 该设置对文本消息无影响,
string类型仍正常接收
断线重连不能只靠 onclose,要主动轮询 readyState 并限制重试次数
onclose 只在连接已关闭后触发,但它不区分“服务端主动断开”和“网络闪断”。单纯监听它再 new WebSocket() 重建,容易陷入无限重连循环(比如 DNS 故障、防火墙拦截导致反复失败)。
- 推荐模式:用
setTimeout+ 指数退避,在onclose和onerror中统一触发重连逻辑 - 必须加最大重试次数(如
5 次)和总超时(如 2 分钟),避免耗尽客户端资源 - 每次重连前检查
ws.readyState,跳过重复新建:let reconnectCount = 0; const MAX_RECONNECT = 5;
function connect() { ws = new WebSocket('wss://api.example.com'); ws.onopen = () => { reconnectCount = 0; }; ws.onclose = () => { if (reconnectCount < MAX_RECONNECT) { reconnectCount++; setTimeout(connect, Math.min(1000 Math.pow(2, reconnectCount), 30000)); } }; ws.onerror = () => { / 同上 */ }; }
WebSocket 的真实复杂度不在连接本身,而在状态同步、消息去重、心跳保活、序列化协议选型这些环节。别让 onmessage 成为唯一关注点。
# javascript
# java
# js
# 前端
# node.js
# node
# nginx
# 防火墙
# 浏览器
# websocket
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Swift中switch语句区间和元组模式匹配
怎么用AI帮你为初创公司进行市场定位分析?
实例解析Array和String方法
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
js代码实现下拉菜单【推荐】
重庆市网站制作公司,重庆招聘网站哪个好?
Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】
昵图网官网入口 昵图网素材平台官方入口
Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理
公司网站制作需要多少钱,找人做公司网站需要多少钱?
网站制作报价单模板图片,小松挖机官方网站报价?
如何自定义建站之星模板颜色并下载新样式?
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
如何快速配置高效服务器建站软件?
高端建站如何打造兼具美学与转化的品牌官网?
七夕网站制作视频,七夕大促活动怎么报名?
Laravel如何使用.env文件管理环境变量?(最佳实践)
canvas 画布在主流浏览器中的尺寸限制详细介绍
Android GridView 滑动条设置一直显示状态(推荐)
Laravel Facade的原理是什么_深入理解Laravel门面及其工作机制
WordPress 子目录安装中正确处理脚本路径的完整指南
javascript中闭包概念与用法深入理解
JavaScript数据类型有哪些_如何准确判断一个变量的类型
如何为不同团队 ID 动态生成多个独立按钮
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
北京企业网站设计制作公司,北京铁路集团官方网站?
如何用PHP快速搭建高效网站?分步指南
如何用景安虚拟主机手机版绑定域名建站?
如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】
Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录
linux写shell需要注意的问题(必看)
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
太平洋网站制作公司,网络用语太平洋是什么意思?
Laravel项目结构怎么组织_大型Laravel应用的最佳目录结构实践
网站制作价目表怎么做,珍爱网婚介费用多少?
Laravel如何处理文件下载请求?(Response示例)
如何在IIS中新建站点并配置端口与IP地址?
php json中文编码为null的解决办法
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
UC浏览器如何设置启动页 UC浏览器启动页设置方法
Laravel如何实现一对一模型关联?(Eloquent示例)
如何在云主机快速搭建网站站点?
bing浏览器学术搜索入口_bing学术文献检索地址
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】
简历在线制作网站免费版,如何创建个人简历?
JavaScript如何实现错误处理_try...catch如何捕获异常?
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?


5 次)和总超时(如 2 分钟),避免耗尽客户端资源