Node+SSE 实现大屏可视化数据实时更新

客户端

1.前期准备

npm install eventsource echarts

 const source = new EventSource('自己的路由sse');
// 连接成功
  source.onmessage = (event) => {
 // 这里面处理自己的业务
    const data = JSON.parse(event.data);
      //data 为服务端 发送的数据

  };

  // 处理连接错误
  source.onerror = (event) => {
    console.log('Connection error:', event);
  };})

服务端 

/**
 * 处理服务器发送事件(Server-Sent Events)的路由。
 * 当客户端请求此路由时,服务器将持续向客户端发送数据。
 * 
 * @param {object} req - 请求对象,包含客户端发起的请求信息。
 * @param {object} res - 响应对象,用于向客户端发送响应。
 */
router.get('/sse', async(req, res) => {
  // 设置响应头,以支持服务器发送事件,禁用缓存并保持连接 alive。
  res.set({
    'Content-Type': 'text/event-stream',
    'Cache-Control': 'no-cache',
    'Connection': 'keep-alive'
  });

  // 立即发送响应头,避免延迟。
  res.flushHeaders();
  // 异步查询用户模型的所有数据。
  //  根据数据库获取数据
  // 每秒向客户端发送一次数据。
  setInterval(() => {
//再此处理你的业务
    // 将查询结果转换为 JSON 字符串并发送给客户端。
    res.write(`data: ${JSON.stringify(此为根据业务获取的数据)}\n\n`);
  }, 1000);
});

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值