当前位置: 首页 > news >正文

EventSource的使用

什么是EventSource
EventSource 是一个用于服务器推送事件(Server-Sent Events, SSE)的接口,它允许服务器推送实时更新到浏览器。与 WebSocket 不同,SSE 是单向的(服务器到客户端),适用于更新频率不高的实时通知、消息推送等场景。下面是关于 EventSource 的详细介绍,包括使用示例和注意事项。

基本概念:服务器向客户端推送实时更新,而不需要客户端发起请求。
使用案例
(使用场景:前端页面需要一次性渲染大数据量时,不能一次性返回,需要服务器不断向前端推送)

  const pageSize = '1000';
    const cstId = params;
    const pageNum = '1';
    const url = `${process.env.VUE_APP_BASE_URL}api/gksk-fund-claim-web/n-fin-ar-demo/210/async?pageSize=${pageSize}&cstId=${cstId}&pageNum=${pageNum}`;
    eventSource.value = new EventSource(url)
    eventSource.value.onmessage = (event) => {
        try {
          const message = JSON.parse(event.data);
          const dataAll = []
          if (message.code === 'DONE') {
            eventSource.value?.close()
            return
          }
          dataAll.push(message.data ? message.data : []);
          dataAll.forEach((item: any) => {
            data.value = [...data.value, ...item]
          })
        } catch (error) {
          eventSource.value?.close()
          console.error('Error parsing message:', error);
        }
      };
      
      eventSource.value.onerror = (error) => {
        console.log('SSE connection error:', error);
        eventSource.value?.close()
      }
      
 //记得在离开页面前销毁,否则造成内存溢出
onUnmounted(() => {
  if (eventSource.value) {
    eventSource.value.close()
  }
})
http://www.dtcms.com/a/17906.html

相关文章:

  • 动态规划LeetCode-494.目标和
  • 百度千帆平台对接DeepSeek官方文档
  • |网络安全|网络安全学习方法
  • 使用deepseek快速创作ppt
  • ESP32无线Wi-Fi蓝牙方案,设备智能连接控制,物联网通信应用
  • SQL入门到精通 理论+实战 -- 在 MySQL 中学习SQL语言
  • java后端开发day14--之前练习的总结和思考
  • 面向对象编程的设计原则
  • 【鱼眼镜头12】Scaramuzza的鱼眼相机模型实操,不依赖于具体的相机几何结构,直接从图像数据出发,因此更具灵活性。
  • 爬虫瑞数5.5案例:某钢材交易官网(面向对象补环境)
  • pyrender smpl 渲染
  • 【C语言】动态内存管理
  • ElementUI表格表头自定义添加checkbox,点击选中样式不生效
  • SQL-leetcode—1661. 每台机器的进程平均运行时间
  • 在 Flutter 实现下拉刷新、上拉加载更多和一键点击回到顶部的功能
  • Vulhub靶机 ActiveMQ 反序列化漏洞(CVE-2015-5254)(渗透测试详解)
  • webpack和vite打包原理及比较
  • PostgreSQL的学习心得和知识总结(一百六十八)|深入理解PostgreSQL数据库之PostgreSQL 规划器开发与调试(翻译)
  • HCIA项目实践--静态路由的综合实验
  • MySQL单表存多大的数据量比较合适
  • Flask使用JWT认证
  • 计数排序
  • 用pytorch实现一个简单的图片预测类别
  • 字符设备驱动开发
  • SpringBoot Bug 日志
  • python_excel批量插入图片
  • 数据结构——队列、哈希存储(2025.2.11)
  • 【ISO 14229-1:2023 UDS诊断全量测试用例清单系列:第十二节】
  • Git 中的 author 和 committer 有什么区别
  • DeepSeek 从入门到精通学习指南,2025清华大学《DeepSeek从入门到精通》正式发布104页pdf版超全解析