前言
在 Web 应用程序中,实时数据推送是一项非常重要的功能。在过去,我们通常使用 WebSocket 技术来实现实时数据推送。但是,WebSocket 技术需要建立一个全双工的连接,对于一些简单的实时数据推送场景来说,这显得过于复杂。而 Server-sent Events 技术则提供了一种更加简单的实现方式。
Server-sent Events 技术是 HTML5 中的一项新特性,它可以在服务器端向客户端推送数据。相比于 WebSocket 技术,Server-sent Events 技术不需要建立全双工的连接,而是通过 HTTP 协议的长连接来实现数据的推送。Server-sent Events 技术还支持自定义事件类型和数据格式,使得它更加灵活和可扩展。
本文将介绍 Server-sent Events 技术的使用方法,并通过一个实战案例来展示 Server-sent Events 技术的应用。
Server-sent Events 的使用方法
创建一个 Server-sent Events 连接
在客户端,我们可以通过 JavaScript 来创建一个 Server-sent Events 连接。以下是创建 Server-sent Events 连接的代码:
const eventSource = new EventSource(url);
其中,url
参数是 Server-sent Events 的服务端地址。在服务端,我们需要通过响应头来指定数据格式和事件类型。以下是一个简单的 Server-sent Events 响应头:
Content-Type: text/event-stream Cache-Control: no-cache
在上面的响应头中,Content-Type
指定了数据格式为 text/event-stream
,Cache-Control
指定了不要缓存响应。
发送数据到客户端
在服务端,我们可以使用 echo
命令来向客户端发送数据。以下是一个简单的 Server-sent Events 响应:
HTTP/1.1 200 OK Content-Type: text/event-stream Cache-Control: no-cache data: Hello, world!\n\n
在上面的响应中,data
字段指定了要发送的数据,\n\n
表示数据传输结束。
接收客户端发送的数据
在客户端,我们可以通过监听 message
事件来接收服务端发送的数据。以下是一个简单的 Server-sent Events 事件监听器:
eventSource.addEventListener('message', (event) => { const data = event.data; console.log(data); });
实战案例:实时股票行情推送
下面,我们将通过一个实战案例来展示 Server-sent Events 技术的应用。我们将使用 Server-sent Events 技术来实现实时股票行情推送。
服务端代码
在服务端,我们将使用 Express 框架来实现一个简单的股票行情推送接口。以下是服务端代码:
-- -------------------- ---- ------- ----- ------- - ------------------- ----- --- - ---------- ------------------ ----- ---- -- - --------- --------------- -------------------- ---------------- ----------- ------------- ------------ --- ----- ---------- - -- -- - ----- ------ - - - ------- ------- ------ ------------- - --- -- - ------- ------- ------ ------------- - ---- -- - ------- ------- ------ ------------- - --- - -- ----------------- ----------- ---------------- -------------------------------- -- ------------- ----------------------- ------ --- ---------------- -- -- - ------------------- ------- -- ---- ------- ---
在上面的代码中,我们使用 Express 框架创建了一个 /stocks
接口。在接口中,我们设置了响应头,指定了数据格式为 text/event-stream
,并且设置了 Connection
为 keep-alive
,表示我们将使用长连接来推送数据。然后,我们在 sendStocks
函数中随机生成几只股票的价格,并通过 Server-sent Events 技术将股票价格推送到客户端。
客户端代码
在客户端,我们将使用 Vue.js 框架来实现一个简单的股票行情推送界面。以下是客户端代码:
-- -------------------- ---- ------- --------- ----- ------ ------ ----- ---------------- --------------------- ------- ------------------------------------------------------------ ------- ------ ---- --------- ------- ------- ---- ------------- ------------- ----- -------- ------- --- ------------ -- ------- -------------------- ------ ------------ ------- ------ ----------- ------- ----- -------- -------- ------ -------- ----- --- - --- ----- --- ------- ----- - ------- -- -- --------- - ----- ----------- - --- ----------------------- -------------------------------------- ------- -- - ----- ---- - ----------------------- ----------- - ----- --- - --- --------- ------- -------
在上面的代码中,我们使用 Vue.js 框架创建了一个股票行情推送界面。在界面中,我们通过 v-for
指令将股票的代码和价格渲染到表格中。然后,在 mounted
钩子函数中,我们创建了一个 Server-sent Events 连接,并监听 stocks
事件。当服务端推送股票行情数据时,我们将数据解析成 JavaScript 对象,并更新界面中的股票行情数据。
运行实例
我们可以使用以下命令来运行上面的实例:
$ node server.js
然后,在浏览器中打开 http://localhost:3000
,即可看到实时股票行情推送界面。每隔一秒钟,界面中的股票行情数据就会自动更新一次。
结论
本文介绍了 Server-sent Events 技术的使用方法,并通过一个实战案例来展示 Server-sent Events 技术的应用。Server-sent Events 技术是一种轻量级的实时数据推送技术,它可以在一些简单的实时数据推送场景中发挥重要作用。在实际开发中,我们可以根据具体业务需求来选择合适的实时数据推送技术。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/673b5dc639d6d08e88b3230f