多个参数用websocket 向io 服务器发送变量,一次发一个,并接收响应

问题:多个参数用websocket 向io 服务器发送变量,一次发一个,并接收响应,如果是多个变量,但还是需要一个个发送,应该怎么实现,思路是什么样子的呢?用数组的话,应该怎么用?

简述一下逻辑:

  1. 初始化 WebSocket 连接:建立与服务器的持久连接。
  2. 参数队列管理:将多个参数存入数组(队列)。
  3. 发送循环:通过递归或循环,每次从队列取出一个参数发送。
  4. 响应处理 :在 onmessage 回调中处理服务器响应,然后触发下一个参数的发送。
javascript 复制代码
// 初始化参数数组和WebSocket连接
const params = ['param1', 'param2', 'param3']; // 待发送的参数列表
let ws = new WebSocket('ws://your-server-url');
let currentIndex = 0; // 当前处理的参数索引

// WebSocket连接成功时触发
ws.onopen = () => {
  sendNextParam(); // 开始发送第一个参数
};

// 接收服务器响应
ws.onmessage = (event) => {
  console.log(`收到响应: ${event.data}`);
  // 处理当前响应后,继续发送下一个参数
  currentIndex++;
  sendNextParam();
};

// 错误处理
ws.onerror = (error) => {
  console.error('WebSocket错误:', error);
};

// 关闭处理
ws.onclose = () => {
  console.log('WebSocket连接已关闭');
};

// 发送下一个参数的函数
function sendNextParam() {
  if (currentIndex < params.length) {
    const param = params[currentIndex];
    console.log(`发送参数: ${param}`);
    ws.send(param); // 发送当前参数
  } else {
    console.log('所有参数已发送完毕');
    // 可选择在此关闭WebSocket连接
    // ws.close();
  }
}

关键点说明:

  • 参数队列 :使用数组 params 存储所有待发送的参数。
  • 顺序控制 :通过 currentIndex 跟踪当前发送的参数位置,确保按顺序发送。
  • 异步响应处理onmessage 回调中递增索引并调用 sendNextParam,保证每个响应处理完成后再发送下一个参数。
  • 边界条件 :当所有参数发送完毕(currentIndex >= params.length)时停止发送。
相关推荐
00后程序员张1 小时前
免Mac上架实战:全平台iOS App上架流程的工具协作经验
websocket·网络协议·tcp/ip·http·网络安全·https·udp
喜欢板砖的牛马1 小时前
简述IPv4分配过程,看这一篇就够了
网络协议
old-six-programmer1 小时前
NAT 类型及 P2P 穿透
服务器·网络协议·webrtc·p2p·nat
GLAB-Mary1 小时前
OSPF虚拟链路术语一览:快速掌握网络路由
网络·智能路由器
tan77º2 小时前
【Linux网络编程】网络基础
linux·服务器·网络
DemonAvenger2 小时前
深入理解Go的网络I/O模型:优势、实践与踩坑经验
网络协议·架构·go
笑衬人心。3 小时前
HTTPS详解:原理 + 加解密过程 + 面试问答
java·网络协议·http·面试·https
bing_1583 小时前
MQTT 和 HTTP 有什么本质区别?
网络·网络协议·http
杨浦老苏5 小时前
Docker端口映射查看工具Dockpeek
网络·docker·群晖
未来之窗软件服务5 小时前
通过网页调用身份证阅读器http websocket方法-华视电子————仙盟创梦IDE
网络·网络协议·http·仙盟创梦ide·东方仙盟·硬件接入