【JS】1699- 重学 JavaScript API - WebSockets API

news2025/1/11 10:57:01

f4c398943c1111017a971fac6744af88.jpeg

前期回顾:

1. Page Visibility API

2. Broadcast Channel API

3. Beacon API

4. Resize Observer API

5. Clipboard API

6. Fetch API

7. Performance API

8. Web Storage API

WebSockets API 提供了一种在客户端和服务器之间建立持久连接的机制,使得实时数据的传输变得更加简单和高效。

🏝 1. 什么是 WebSockets API

1.1 概念介绍

WebSockets API 「允许在浏览器和服务器之间进行双向通信」。相比传统的 HTTP 请求-响应模式,WebSockets 允许服务器主动向客户端推送数据,实现实时性和双向通信。它建立在标准的 HTTP 协议之上,使用标准的 WebSocket URL 进行通信。

1.2 作用和使用场景

WebSockets API 有许多有用的场景场景,包括实时聊天应用、多人协作工具、实时数据监控和游戏等。通过使用 WebSockets,开发者可以轻松地实现实时更新、即时通知和实时数据传输等功能,提供更好的用户体验。

🎨 2. 如何使用 WebSockets API

WebSockets API 的使用相对简单,只需要几个基本步骤:

  1. 「建立 WebSocket 连接」

在客户端代码中,使用 JavaScript 创建一个 WebSocket 对象,并通过 WebSocket URL 建立与服务器的连接。

const socket = new WebSocket("ws://example.com/socket");
  1. 「处理连接事件」

在连接建立后,WebSocket 对象会触发不同的事件,我们可以监听这些事件来处理连接状态和接收数据。

socket.onopen = () => {
  console.log("WebSocket 连接已建立");
};

socket.onmessage = (event) => {
  console.log("收到消息:", event.data);
};

socket.onclose = () => {
  console.log("WebSocket 连接已关闭");
};
  1. 「发送和接收数据」

通过 WebSocket 对象的 send() 方法发送数据到服务器,服务器可以使用 send() 方法将数据发送给客户端。

// 发送数据
socket.send("Hello, Server!");

// 接收数据
socket.onmessage = (event) => {
  console.log("收到消息:", event.data);
};
  1. 「关闭连接」

当不再需要使用 WebSocket 连接时,可以通过调用 WebSocket 对象的 close() 方法来关闭连接。

socket.close();

🧭 3. WebSockets API 的实际应用

WebSockets API 在许多实际应用中发挥着重要作用。下面是几个常见的应用场景:

3.1 实时聊天应用

WebSockets 可以用于构建实时聊天应用,其中用户可以实时地发送和接收消息。通过建立持久的 WebSocket 连接,用户可以即时收到其他用户发送的消息,从而实现实时的聊天体验。

// 客户端代码
const socket = new WebSocket("ws://example.com/chat");

socket.onmessage = (event) => {
  const message = JSON.parse(event.data);
  displayMessage(message);
};

function sendMessage(message) {
  socket.send(JSON.stringify(message));
}

3.2 实时数据监控

WebSockets 可以用于监控实时数据的变化。例如,一个实时股票市场监控应用可以通过 WebSocket 连接获取实时的股票价格,并将其实时显示给用户。

// 客户端代码
const socket = new WebSocket("ws://example.com/stocks");

socket.onmessage = (event) => {
  const stockData = JSON.parse(event.data);
  displayStockPrices(stockData);
};

3.3 游戏开发

WebSockets API 为多人游戏开发提供了强大的基础。游戏服务器可以使用 WebSockets 与客户端建立双向通信,并实时传输游戏状态和玩家的动作。

// 客户端代码
const socket = new WebSocket("ws://example.com/game");

socket.onmessage = (event) => {
  const gameData = JSON.parse(event.data);
  updateGame(gameData);
};

function sendPlayerAction(action) {
  socket.send(JSON.stringify(action));
}

📋 4. 兼容性和优缺点

4.1 兼容性

以下是 WebSockets API 的兼容性列表,包含了主流浏览器及其支持的最低版本:

  • Chrome 4+✅

  • Firefox 4+✅

  • Safari 5+✅

  • Edge 12+✅

  • Opera 11.5+✅

  • Internet Explorer 10+✅

  • iOS Safari 4.2+✅

  • Android Browser 4.4+✅

  • Chrome for Android 33+✅

  • Firefox for Android 4+✅

cbd71a9892071882b3d7d0583afda24f.png

可以在 Can I use[1] 网站上查看 WebSockets API 的兼容性详情。

4.2 优缺点

WebSockets API 具有以下优点:

  • 「实时性」

通过建立持久连接,实现「实时数据传输」「双向通信」

  • 「较低的延迟」

相比传统的轮询机制,WebSockets 可以「减少无效的请求和响应」,降低延迟。

  • 「节省带宽」

由于「不需要频繁的请求和响应」,WebSockets 在传输数据方面更加高效。

然而,WebSockets API 也有一些缺点:

  • 「兼容性问题」

尽管现代浏览器广泛支持 WebSockets,但某些旧版本浏览器可能不支持或存在一些限制。在设计应用程序时,需要考虑到兼容性问题,并提供备选方案来处理不支持 WebSockets 的情况。

  • 「服务器开销」

与传统的 HTTP 请求-响应模式相比,WebSockets 需要服务器维护持久连接,这可能增加服务器的负载。

  • 「安全性考虑」

由于 WebSockets 允许服务器主动推送数据到客户端,因此需要仔细考虑安全性问题,防止潜在的安全漏洞。

4.3 工具推荐

推荐几个常用工具:

  • Socket.IO[2] 58.2K⭐

一个面向实时应用程序的 JavaScript 框架,提供了跨浏览器的双向通信。它支持实时聊天、实时分析和实时协作等场景。

  • ws[3] 19.8K⭐

一个简单易用的 WebSocket 客户端和服务器库,适用于 Node.js。它提供了基本的 WebSocket 功能,并支持自定义扩展。

  • uWebSockets[4] 15.4K⭐

一个快速、轻量级的 WebSocket 库,可用于构建高性能的实时应用程序。它提供了简单易用的接口,并支持多线程和事件驱动的架构。

  • SignalR[5] 8.9K⭐

一个为 ASP.NET 开发人员提供的实时 Web 功能库,可在浏览器和服务器之间建立双向通信。它支持多种客户端技术,包括 JavaScript、.NET 和 Xamarin。

  • sockjs-client[6] 8.2K⭐

一个用于创建跨浏览器实时应用程序的 JavaScript 库,它提供了类似 WebSocket 的 API,并在不支持 WebSocket 的浏览器中使用轮询技术进行回退。

👍 5. 使用建议和注意事项

以下是一些使用建议和注意事项:

  • 「考虑兼容性」

在设计和实施应用程序时,需要考虑到不同浏览器和平台的兼容性,并提供备选方案来处理不支持 WebSockets 的情况。

  • 「处理连接中断」

在客户端代码中,需要处理连接中断和错误的情况,例如网络故障或服务器断开连接。可以通过监听 oncloseonerror 事件来捕获这些情况。

  • 「安全性措施」

确保对 WebSocket 连接进行适当的安全性措施,以防止潜在的安全漏洞和攻击。使用安全的连接(wss://)和合适的认证和授权机制。

  • 「考虑服务器负载」

由于 WebSockets 需要维护持久连接,服务器的负载可能会增加。在设计服务器架构时,需考虑负载均衡和扩展性。

  • 「数据传输量控制」

注意控制数据传输量,避免过多的数据传输对带宽和性能产生负面影响。

🍭 6. 总结

WebSockets API 为实时性和双向通信提供了便捷的解决方案。通过使用 WebSockets,开发者可以轻松构建实时聊天应用、实时数据监控和多人游戏等应用程序。WebSockets API 的广泛支持和强大功能使其成为现代 Web 开发中不可或缺的一部分。通过合理的使用和注意事项,我们可以充分利用 WebSockets 实现更好的用户体验和功能。

🎯 7. 拓展阅读

  • WebSockets API 文档[7]

  • WebSockets 兼容性[8]

  • Introducing WebSockets - Bringing Sockets to the Web[9]

Reference

[1]

Can I use: https://caniuse.com/?search=websockets

[2]

Socket.IO: https://socket.io/

[3]

ws: https://github.com/websockets/ws

[4]

uWebSockets: https://github.com/uWebSockets/uWebSockets

[5]

SignalR: https://github.com/SignalR/SignalR

[6]

sockjs-client: https://github.com/sockjs/sockjs-client

[7]

WebSockets API 文档: https://developer.mozilla.org/en-US/docs/Web/API/WebSocket

[8]

WebSockets 兼容性: https://caniuse.com/websockets

[9]

Introducing WebSockets - Bringing Sockets to the Web: https://web.dev/websockets-basics/

往期回顾

#

如何使用 TypeScript 开发 React 函数式组件?

#

11 个需要避免的 React 错误用法

#

6 个 Vue3 开发必备的 VSCode 插件

#

3 款非常实用的 Node.js 版本管理工具

#

6 个你必须明白 Vue3 的 ref 和 reactive 问题

#

6 个意想不到的 JavaScript 问题

#

试着换个角度理解低代码平台设计的本质

4ecdb1c50918701d7a7a6ffc58072049.gif

回复“加群”,一起学习进步

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/596087.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于轻量级YOLOv5n/s/m三款模型开发构建基于无人机视角的高空红外目标检测识别分析系统,对比测试分析性能

有关于无人机目标检测和红外场景下的目标检测的项目在我之前的文章中都有实践经历了,但是将无人机和红外场景结合的目标检测项目还是很少的,本文的核心想法就是基于高空无人机场景开发构建目标检测系统。 前面相关博文如下,感兴趣的话可以自…

Python潮流周刊#4:Python 2023 语言峰会

△点击上方“Python猫”关注 ,回复“1”领取电子书 你好,我是猫哥。这里记录每周值得分享的 Python 及通用技术内容,本期是特别加更版,聚焦于 Python 官方 2023 年语言峰会的系列博客。 由于公众号不支持外链,文中大量…

JetBrains的PHP集成开发环境PhpStorm 2023版本在Win10系统的下载与安装配置教程

目录 前言一、PhpStorm 安装二、使用配置总结 前言 PhpStorm是一款专为PHP开发人员设计的集成开发环境(IDE)。它提供了丰富的功能和工具,可以帮助开发人员更高效地编写、调试和部署PHP应用程序。 PhpStorm的主要特点: ——代码…

硬件大熊原创合集(2023/04-05更新)

04-05月份更新篇章: NFC模块化设计方案 一款射频芯片的layout设计指导案例-篇章1 04月份娃出生,连续两个月需要处理的各种事情比之前多了很多,还好慢慢地适应了这种节奏,并且逐渐开始挖掘出属于个人的时间。 有天夜里抱着娃哄睡时…

NIO之Buffer解读

目录 Buffer 简介 Buffer 的基本用法 使用步骤 使用 Buffer 的例子 使用 IntBuffer 的例子 Buffer 的 capacity、position 和 limit capacity position limit Buffer 的类型 Buffer 分配和读写数据 Buffer 分配 向 Buffer 中写数据 flip()方法 从 Buffer 中读取数…

C++ Lambda 表达式:深入理解与应用

C Lambda 表达式是 C11 标准引入的一项强大功能,它允许开发者以简洁、优雅的方式创建匿名函数对象。 本文将深入探讨 C Lambda 表达式的原理、语法和应用场景,帮助读者更好地理解和使用这一功能。 1. Lambda 表达式简介 Lambda 表达式是一种创建匿名函数…

18. Vue-element-template白天黑夜模式动态切换

两套主题动态切换 1. 去官网生成两套主题拷贝到 resources/src/assets/theme https://element.eleme.cn/#/zh-CN/theme 2. 也可以本地修改 element-variables.scss 然后运行et生成 安装 (注意Node版本) ➜ Genes-Admin git:(ogenes) sudo n 10.16.…

【车载开发系列】Autosar DEM基本概念

【车载开发系列】Autosar DEM基本概念 Autosar DEM基本概念 【车载开发系列】Autosar DEM基本概念一. 诊断事件管理(DEM)概念二. DEM的主要作用1、汽车检修提供数据2、汽车错误状态处理提供依据 三. DEM模块及关联模块关系1. 功能禁止模块FIM2. SWC和BSW3. NvM非易失性存储4. 诊…

分布式存储Ceph介绍及搭建

一:存储的类型 1.单机存储设备 ●DAS(直接附加存储,是直接接到计算机的主板总线上去的存储) IDE、SATA、SCSI、SAS、USB 接口的磁盘 所谓接口就是一种存储设备驱动下的磁盘设备,提供块级别的存储 ●NAS(…

一、docker-compose方式安装运行Jenkins

docker-compose方式安装运行Jenkins 服务器系统:centos 7.6 以docker-compose 编排容器方式安装,当然需提前安装docker-compose环境(见百度->docker-compose环境安装) docker-compose.yml version: 3.1 services:jenkins:i…

率先领跑!人大金仓布局“数字医疗”护航健康中国

近日,中国医院信息网络大会(CHIMA 2023)在福州圆满结束。作为数据库领域唯一参展企业,人大金仓携一系列“数字医疗”国产数据库解决方案亮相,在激发数据价值,促进数据资源整合利用,确保数据安全使用等方面的突出表现和…

死神来了 | 高铁出轨:“德国的泰坦尼克号事件”

点击文末“阅读原文”即可收听本期节目 剪辑、音频 / 伊姐 运营 / SandLiu 卷圈 封面 / 姝琦Midjourney 监制 / 姝琦 产品统筹 / bobo 场地支持 / 声湃轩天津录音间 德国高铁出轨事故是1998年6月3日发生于德国下萨克森州策勒县艾雪德镇附近的严重铁路事故,造成…

华为OD机试真题B卷 Java 实现【合法IP】,附详细解题思路

一、题目描述 IPV4地址可以用一个32位无符号整数来表示,一般用点分方式来显示,点将IP地址分成4个部分,每个部分为8位,表示成一个无符号整数(因此正号不需要出现),如10.137.17.1,是我…

在中文LLaMA模型上进行精调

最近在开源项目ymcui/Chinese-LLaMA-Alpaca的基础上完成了自己的中文模型精调工作,形成了两个工具共享给大家。ymcui/Chinese-LLaMA-Alpaca 构建指令形式的精调文件 如果用于精调,首先要准备精调数据,目标用途如果是问答,需要按…

【下篇】我们邀请了4位专家来探讨消费市场的新增量:W型机会、单客经济、日本市场、DTC......

在4月底的时候,我们举办了一场线上直播活动,有幸邀请到了4位消费零售行业的专家,我本人与他们一起探讨如何寻找市场的新增量,思考品牌如何找到新机会。本篇内容就是将专家们的观点进行了梳理和总结。 接上篇内容: 本篇…

【六·一】就做个纯粹的小小游戏吧

写在前面:博主是一只经过实战开发历练后投身培训事业的“小山猪”,昵称取自动画片《狮子王》中的“彭彭”,总是以乐观、积极的心态对待周边的事物。本人的技术路线从Java全栈工程师一路奔向大数据开发、数据挖掘领域,如今终有小成…

Java学习(maven)——maven新建项目 常用IO工具 Durid数据库工具 案例

引出 如何用maven新建项目,用maven建项目的优势,常用的io工具和durid工具 用Maven建项目 0.Maven配置方式 参考博客 : 【配置】Maven的配置 & Tomcat的配置 & 在IDEA中新建web项目 中的maven配置 1.io流的工具IOUtils/FileUtils…

ROS:一些基本命令行

目录 一、打开小海龟1.1终端,启动ROS Master:1.2终端2,启动小海龟仿真器:1.3终端3,启动海龟控制节点: 二、查看系统中的计算图三、节点命令3.1查看节点下的命令rosnode3.2显示节点列表rosnode list3.3查看节…

【致敬未来的攻城狮计划】打卡1:rasc+keil环境搭建

前言 这回参加的是csdn李肯老师的攻城狮计划,简单说就是我白嫖板子,输出学习笔记。 板子是瑞萨的CPK_RA2E1,还有触摸元件,看起来很有意思hh。 环境搭建 一开始决定采取vscode搭建的方式。后期进行到最后一步——cmake build的时…

多链路传输技术在火山引擎 RTC 的探索和实践

动手点关注 干货不迷路 传统的数据传输方式大多是利用一个链路、选择设备的默认网卡进行传输,使用这种方式实现实时音视频通话时,如果默认网络出现问题(如断网、弱网等),用户的通信就会发生中断或者卡顿,影…