HTML SSE是什么?实时更新的3种Server-Sent事件用法

sse(server-sent events)是一种服务器向客户端推送实时数据的单向通信方式,适用于股票行情、新闻推送、聊天消息等场景。1. 使用javascript连接sse流的方法是创建eventsource对象并监听事件,如onmessage处理默认消息,onerror处理错误,addeventlistener监听自定义事件;2. 服务器端发送sse事件需设置content-type为text/event-stream,并按格式发送以data:开头、nn结尾的数据,示例使用node.js每秒推送递增消息;3. 发送带事件id和自定义类型的sse消息可通过添加id:和event:字段实现,客户端可据此跟踪事件id并监听特定类型事件,如示例中根据奇偶id发送不同类型事件。

HTML SSE是什么?实时更新的3种Server-Sent事件用法

HTML SSE,简单来说,就是服务器向客户端推送数据的单向通道。它让网页无需频繁请求,就能实时更新信息,像股票行情、新闻推送、聊天室消息,都能用它实现。

HTML SSE是什么?实时更新的3种Server-Sent事件用法

解决方案:

Server-Sent Events (SSE) 提供了一种从服务器向客户端推送实时数据的高效方式。以下是三种常用的 SSE 用法,并附带代码示例。

立即学习“前端免费学习笔记(深入)”;

HTML SSE是什么?实时更新的3种Server-Sent事件用法

如何使用JavaScript连接到SSE流?

使用 JavaScript 连接到 SSE 流非常简单。你需要创建一个 EventSource 对象,指向你的 SSE 端点。然后,你可以监听不同的事件类型来处理服务器推送的数据。

const eventSource = new EventSource('/sse-endpoint');eventSource.onmessage = (event) => {  console.log('Received data:', event.data);  // 在这里更新你的页面内容};eventSource.onerror = (error) => {  console.error('SSE error:', error);  eventSource.close(); // 发生错误时关闭连接};eventSource.addEventListener('custom_event', (event) => {  console.log('Received custom event:', event.data);  // 处理自定义事件});

这段代码创建了一个连接到 /sse-endpointEventSourceonmessage 处理默认的数据推送,onerror 处理错误,而 addEventListener 可以监听服务器发送的自定义事件。注意,错误发生时最好关闭连接,防止无限重试。

HTML SSE是什么?实时更新的3种Server-Sent事件用法

如何在服务器端发送SSE事件?

服务器端发送 SSE 事件需要设置正确的 HTTP 头部,并按照特定格式发送数据。重要的是 Content-Type 必须是 text/event-stream

以下是一个 Node.js 示例:

const http = require('http');http.createServer((req, res) => {  res.writeHead(200, {    'Content-Type': 'text/event-stream',    'Cache-Control': 'no-cache',    'Connection': 'keep-alive'  });  let i = 0;  setInterval(() => {    const data = `data: Hello, SSE! ${i}nn`;    res.write(data);    i++;  }, 1000);  req.on('close', () => {    console.log('Client disconnected');  });}).listen(3000, () => {  console.log('SSE server started on port 3000');});

这个服务器每秒发送一条包含递增数字的消息。关键在于 Content-Type 设置为 text/event-stream,并且每个事件以 data: 开头,以 nn 结尾。 Cache-Control: no-cache 也很重要,防止浏览器缓存 SSE 流。

如何发送带有事件ID和自定义事件类型的SSE?

除了基本的数据推送,你还可以发送带有事件 ID 和自定义事件类型的 SSE。这允许客户端更好地管理和处理不同的事件。

const http = require('http');http.createServer((req, res) => {  res.writeHead(200, {    'Content-Type': 'text/event-stream',    'Cache-Control': 'no-cache',    'Connection': 'keep-alive'  });  let eventId = 0;  setInterval(() => {    eventId++;    const eventType = (eventId % 2 === 0) ? 'even' : 'odd';    const data = `id: ${eventId}nevent: ${eventType}ndata: Event ${eventId} of type ${eventType}nn`;    res.write(data);  }, 1000);  req.on('close', () => {    console.log('Client disconnected');  });}).listen(3000, () => {  console.log('SSE server started on port 3000');});

在这个例子中,我们添加了 idevent 字段。id 用于标识事件,客户端可以使用 lastEventId 属性来跟踪最后一个事件。event 字段定义了事件类型,客户端可以使用 addEventListener 监听特定类型的事件。例如,客户端可以监听 “even” 和 “odd” 事件,并分别处理它们。

服务器端需要按照规范,使用 id:, event:data: 字段,并以 nn 分隔每个事件。客户端则使用 addEventListener 监听自定义事件。

以上就是HTML SSE是什么?实时更新的3种Server-Sent事件用法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1568859.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月22日 11:56:25
下一篇 2025年12月22日 11:56:33

相关推荐

  • HTML数据表格怎么优化?移动端友好的6种响应式技巧

    /* 默认显示所有列 */.my-table th, .my-table td { /* … 基础样式 … */}/* 在小屏幕上隐藏不那么重要的列 */@media (max-width: 768px) { .my-table .hide-on-mobile { display: none…

    2025年12月22日 好文分享
    000
  • HTML5的WebRTC是什么?如何实现视频通话?

    webrtc在视频通话中扮演核心角色,它实现浏览器间的实时音视频和数据传输。具体流程包括:1. 获取本地媒体流;2. 创建rtcpeerconnection实例;3. 添加本地媒体流到peerconnection;4. 处理远端媒体流;5. 通过信令服务器交换sdp offer/answer;6. …

    2025年12月22日 好文分享
    000
  • HTML5的Translate属性有什么用?如何防止内容被翻译?

    html5的translate属性用于控制内容是否应被翻译,通过设置translate=”no”可防止特定元素内容被机器翻译。1. 它适用于品牌名称、代码片段、法律声明等需保持原语言的内容;2. 其工作原理是向翻译工具提供提示,但无法完全阻止翻译,仅作为建议;3. 除该属性外…

    2025年12月22日 好文分享
    000
  • HTML表格的border属性有什么作用?如何设置边框样式?

    html表格的border属性用于定义边框,但现代开发更推荐使用css实现更精细控制。1. border属性仅能简单控制边框显示与否,无法调整样式细节;2. 使用css可通过border-collapse、border-style、border-width、border-color等属性实现多样化样…

    2025年12月22日 好文分享
    000
  • HTML离线应用怎么实现?提升访问速度的3种manifest技巧

    html离线应用的核心是通过.manifest文件实现资源缓存,具体步骤包括:1. 创建.manifest文件并定义cache、network、fallback三部分;2. 在标签中引用manifest属性;3. 利用版本控制触发缓存更新。其原理为首次访问时下载清单并缓存指定资源,后续访问优先从本地…

    2025年12月22日 好文分享
    000
  • HTML变量怎么使用?模板字符串的4种${}插入技巧

    javascript模板字符串是实现动态html内容的现代工具,其核心在于${}语法,摘要如下:1.嵌入变量与常量,将变量值直接插入字符串;2.嵌入算术与逻辑表达式,实现动态计算与条件渲染;3.嵌入函数调用,执行复杂逻辑后返回结果;4.访问对象属性与数组元素,处理结构化数据。模板字符串提升代码可读性…

    2025年12月22日 好文分享
    000
  • HTML中如何标记装饰性图片?

    在html中正确标记装饰性图片的方法是使用css背景图片或设置alt=””,以确保无障碍访问和语义化。1. 优先使用css背景图片,通过.class {background-image: url();}方式实现,分离结构与样式;2. 若必须使用标签,则设置alt=&#8221…

    2025年12月22日 好文分享
    000
  • 如何为HTML标签组添加可访问性?

    为html标签组添加可访问性的核心在于优先使用语义化html5元素,结合aria属性进行补充,并确保键盘导航和焦点管理得当。1. 优先使用原生语义化html元素,如 、 、 、、等,以提供默认的语义和行为;2. 在原生html不足以表达复杂组件时,合理使用wai-aria的角色和属性,如role、a…

    2025年12月22日 好文分享
    000
  • 为什么HTML需要避免使用全大写文本?

    避免使用全大写文本的原因有:1. 影响阅读体验,因缺乏字母升部和降部,导致单词形状单一,增加辨认难度;2. 易被误解为情绪激动,造成用户不适;3. 不符合html语义规范,应通过css实现样式控制;4. 对可访问性不利,可能干扰屏幕阅读器朗读并加重阅读障碍用户的负担;5. 使用css的text-tr…

    2025年12月22日 好文分享
    000
  • HTML支付页面怎么设计?提升信任感的7种安全方案

    设计html支付页面提升信任感的核心在于将安全技术与用户体验融合。1.强制https加密确保传输安全;2.敏感数据令牌化避免存储风险;3.前后端双重验证防范攻击;4.接入权威第三方支付网关增强可信度;5.清晰错误提示保护系统信息;6.展示安全标识与合规标志建立视觉信任;7.防篡改表单结构设计保障输入…

    2025年12月22日 好文分享
    000
  • 什么是HTML可访问性快捷键?如何设置?

    html可访问性快捷键存在多个局限性,1. 快捷键易与浏览器或系统默认快捷键冲突,导致用户困惑;2. 可发现性差,用户难以知晓快捷键设置;3. 不同浏览器和操作系统间组合键不一致,增加学习成本;4. 不符合wcag推荐的主要导航机制,可能影响可用性。更推荐的替代方案包括:1. 使用语义化html标签…

    2025年12月22日 好文分享
    000
  • 为什么HTML需要避免使用小字体?

    小字体影响用户体验、可访问性及seo。1. 用户体验方面,小字体会导致阅读疲劳、降低信息获取效率,尤其在移动端加剧操作不便。2. 可访问性上,小字体阻碍视力障碍者正常使用,违背wcag无障碍标准。3. seo层面,高跳出率、低停留时间及差移动体验会降低搜索引擎排名。4. 解决方案包括:设定至少16p…

    2025年12月22日 好文分享
    000
  • 如何为HTML表格添加复选框?如何批量操作?

    在html表格中实现复选框及批量操作功能,需结合html结构和javascript逻辑,并关注用户体验、状态同步、性能优化与可访问性。1. 在表头添加“全选/全不选”复选框,在每行数据前添加“单选”复选框,并通过javascript监听其状态变化以联动更新;2. 使用事件委托管理动态生成的行复选框,…

    2025年12月22日 好文分享
    000
  • 如何为HTML颜色选择器添加可访问性?

    标准的 在可访问性方面存在局限,1. 因其类似“黑盒”,浏览器实现差异大,键盘操作不一致;2. 内部结构难以控制和添加语义化标记,缺乏aria钩子;3. 样式定制受限,焦点指示器不易增强;4. 弹窗形式带来焦点管理难题。为提升自定义颜色选择器的可访问性,1. 使用 role=”slide…

    2025年12月22日 好文分享
    000
  • HTML中如何正确使用aria-busy?

    aria-busy适用于动态内容区域以提升可访问性,其使用场景包括异步加载内容、表单提交状态更新、实时数据刷新仪表板。1. 异步加载内容区域:如无限滚动列表、ajax表格或图表更新时,通过设置aria-busy=”true”防止屏幕阅读器读取不完整信息;2. 表单提交后的状态…

    2025年12月22日 好文分享
    000
  • HTML主题切换怎么实现?用户选择的4种样式表技巧

    要实现html主题切换,主要方法包括使用css变量和javascript、切换css文件、记住用户选择及优化性能。1. 使用css变量和javascript动态修改样式,灵活但需编写js代码;2. 通过标签切换不同css文件,简单但加载速度较慢;3. 利用localstorage存储用户偏好,实现持…

    2025年12月22日 好文分享
    000
  • 如何为HTML模态对话框设计可访问性?

    要设计可访问的html模态对话框,需确保所有用户都能无障碍理解、互动和关闭对话框。1.使用语义化标签如或role=”dialog”与aria-modal=”true”以增强可访问性;2.通过aria-labelledby关联标题,提升辅助技术识别度;3…

    2025年12月22日 好文分享
    000
  • HTML中如何标记内容的主要语言?

    在html中,标记内容的主要语言主要通过在标签上使用lang属性实现。1. lang属性值应符合bcp 47标准的语言代码,如zh-cn表示简体中文,en表示英语;2. 添加lang属性有助于提升可访问性,辅助技术能正确识别并朗读内容;3. 对seo有积极作用,帮助搜索引擎准确理解页面语言和受众;4…

    2025年12月22日 好文分享
    000
  • HTML中如何标记必填表单字段?

    在html中,标记必填表单字段最直接的方式是使用required属性。1. 通过在、、等输入元素上添加required布尔属性,浏览器会在提交时自动验证这些字段是否填写;2. 若未填写,浏览器会阻止提交并显示默认提示信息;3. 此方法提升用户体验和数据完整性,避免用户因遗漏必填项而反复提交;4. 然…

    2025年12月22日 好文分享
    000
  • HTML5的Input的List属性有什么用?如何绑定DataList?

    html5的元素通过与元素的list属性结合,为用户提供预定义选项以提升输入体验。使用方法是:1. 创建包含多个的并设置其id;2. 将的list属性指向该id。动态绑定时可通过javascript操作dom添加选项,如遍历json数据创建元素并追加到中。兼容性方面,现代浏览器普遍支持,但在ie9及…

    2025年12月22日 好文分享
    000

发表回复

登录后才能评论
关注微信