vue3项目使用EventSource实现流式输出例如滚动日志

devtools/2024/10/9 0:42:59/

前言

之前接触的通信方式主要是HTTP请求和WebSocket,这次有机会了解到EventSource,记录一下。

简介

EventSource是一个浏览器端用于接收服务器推送事件(Server-Sent Events, SSE)的 JS API。与 WebSocket 不同,SSE 是单向的(服务器到客户端),适用于更新频率不高的实时通知、消息推送等场景。

基本用法

创建连接

javascript">const eventSource = new EventSource('后台提供的接口地址');

监听数据上报

javascript">eventSource.addEventListener('后台定义的事件类型这个名字前后端需要保持一致', (event) => {console.log('Custom Event:', event.data);});

 捕获错误

我用的时候想在这个error里获取接口的状态码,但是发现没有,所以作罢。

javascript">eventSource.onerror = (error: any) => {console.log(error);}

 关闭连接

javascript">eventSource.close();

应用

通过一个简易的滚动日志功能来运用一下EventSource吧。语法是vue3+ts。

其中滚动条始终滚动到最底部相关的逻辑参考如下,这位大佬分享的很详细!VUE中如何让滚动条保持在最底部(数据实时更新,页面高度随时变化)_vue滚动条自动滚动到底部-CSDN博客

HTML代码

<template><div ref="logElRef"><div v-for="log in logList" :key="log">{{ log }}</div></div>
</template>

JS代码 

javascript"><script setup lang="ts">
import { inject, ref, nextTick, onMounted, onBeforeUnmount } from 'vue';const logElRef = ref();
const logList = ref([]);
const oldScrollTop = ref(0);
const scrollFlag = ref(true);
const eventSource = ref();
// 建立连接
const initSSE = () => {eventSource.value = new EventSource('后台提供的接口地址');// 监听自定义的事件eventSource.value.addEventListener('后台定义的事件类型这个名字前后端需要保持一致', (event) => {console.log('Custom Event:', event.data);logList.push(event.data);// 保存流式数据if (scrollFlag.value) {scrollToBottom(); // 数据更新后滚动到最底部,始终让最新的数据可见}});// 监听接收到的消息,但我用这个方式监听不到数据,不知道为啥//eventSource.value.onmessage = (event: any) => {// console.log('Event:', event.data);//}
// 捕获异常eventSource.value.onerror = (error: any) => {console.log(error);}
}
// 关闭连接
const closeSSE = () => {eventSource.value?.close();
};// 使滚动条置底
const scrollToBottom = () => {nextTick(() => {logElRef.value.scrollTop = logElRef.value.scrollHeight;})
}
// 监听滚动事件
const scrolling = () => {let scrollTop = logElRef.value.scrollTop;// 更新——滚动前,滚动条距文档顶部的距离let scrollStep = scrollTop - oldScrollTop.value;oldScrollTop.value = scrollTop;//判断当前是向上or向下滚动if (scrollStep < 0) {//向上scrollFlag.value = false;} else {scrollFlag.value = true;}
}
onMounted(() => {
// 进入页面后开始创建连接监听数据上报并监听滚动条事件,始终让滚动条在最底部,最新的数据可见initSSE();logElRef.value.addEventListener('scroll', scrolling);scrollToBottom();
})
onBeforeUnmount(() => {closeSSE();logElRef.value.removeEventListener('scroll', scrolling);
})
</script>

样式代码

<style scoped>
.log-wrap {width: 100%;min-height: 500px;max-height: 1780px;overflow-x: hidden;overflow-y: auto;
}
</style>


http://www.ppmy.cn/devtools/103498.html

相关文章

Linux CentOS 添加路由

一、临时添加 查看当前路由表 ip route show添加路由 假设你要添加一条到特定网络的路由&#xff0c;可以使用以下命令&#xff1a; sudo ip route add <destination_network>/<netmask> via <gateway> dev <interface>例如&#xff0c;要添加一条…

Dockerfile应用、私有仓库

通过dockerfile创建⼀个在启动容器时&#xff0c;就可以启动httpd服务的镜 像 步骤 1. 创建⼀个⽬录&#xff0c;⽤于存储Docker file所使⽤的⽂件 1. 在此⽬录中创建Docker file⽂件&#xff0c;以及镜像制作所使⽤的⽂件 1. 使⽤docker build创建镜像 1. 使⽤创建的镜像…

数学建模学习(123):使用Python实现ARAS方法进行多准则决策实战

文章目录 1 引言1.1 简介1.2 ARAS方法的基本原理2. 案例分析:设备采购决策2.1. 数据集的构建2.2 权重的设定2.3. 准则类型的设定2.4. ARAS方法实现2.5. 结果分析1 引言 1.1 简介 多准则决策分析(MCDA)是一种用于帮助决策者在多个备选方案和多个相互冲突的准则中选择最佳方…

Golang学习总结

一、基本语法 Golang 设计理念&#xff1a;一种事情有且只有一种方法完成 软件包安装 直接官网下载好&#xff0c;配置安装下环境变量即可 /etc/profile # 在这个文件写入会对所有用户生效 ~/.profile # 在这个文件写入只会对当前用户生效# 以上两个文件中…

HarmonyOS NEXT未成年人模式无缝联动所有应用,过滤非适龄内容

背景 随着消费电子产品和移动互联网的普及&#xff0c;未成年人互联网普及率96.8%&#xff0c;超过80%的未成年人都拥有自己的上网设备&#xff0c;而如何引导孩子正确上网一直是家长们的担忧。市场上很多电子设备、系统推出了一些未成年人管控能力&#xff0c;却需要家长到各…

进程、线程的区别

进程&#xff08;Process&#xff09;和线程&#xff08;Thread&#xff09;是操作系统中的基本概念&#xff0c;它们在资源管理和任务执行方面有着本质的区别&#xff1a; 定义&#xff1a; 进程&#xff1a;进程是操作系统进行资源分配和调度的一个独立单位。每个进程都有自己…

5220条执业助理医师题库ACCESS\EXCEL数据库

今天这份数据库与《4820道西#医综合真题西医真题ACCESS数据库》、《4170条中#医综合真题中医真题ACCESS\EXCEL数据库》结构相同&#xff0c;包含5千多道真题。这个数据库包含3个表&#xff0c;一个是分类表&#xff08;SECTION_BEAN&#xff09;&#xff0c;一个是题库主表&…

OpenCV详细介绍

OpenCV是一个广泛使用的开源计算机视觉库&#xff0c;使用C语言编写。它提供了丰富的图像处理和计算机视觉算法&#xff0c;可以用于图像和视频的处理、特征提取、目标检测、人脸识别、运动跟踪等多个领域。 OpenCV的主要特点包括&#xff1a; 跨平台性&#xff1a;OpenCV可以…