HTML5 服务器发送事件(server-sent event)允许网页获得来自服务器的更新。+ a& c3 f/ `: _6 r! z" E
1 [- |7 k6 @ [& X5 H7 w4 b4 @ b' z4 q8 n
Server-Sent 事件 - 单向消息传递Server-Sent 事件指的是网页自动获取来自服务器的更新。 以前也可能做到这一点,前提是网页不得不询问是否有可用的更新。通过服务器发送事件,更新能够自动到达。 例子:Facebook/Twitter 更新、股价更新、新的博文、赛事结果等。
% ~1 ~4 N( z2 P4 m/ H接收 Server-Sent 事件通知EventSource 对象用于接收服务器发送事件通知: - var source=new EventSource("demo_sse.php");& }, z# u' A) [8 c9 `. T
- source.onmessage=function(event)
+ o# ~5 B& l0 Z* P, N- T' {7 N - {( y8 Y: Y. o: {& a
- document.getElementById("result").innerHTML+=event.data + "<br>";, J6 `2 J5 ~0 W$ M( H) C0 ]
- };
复制代码实例解析: - 创建一个新的 EventSource 对象,然后规定发送更新的页面的 URL(本例中是 "demo_sse.php")
- 每接收到一次更新,就会发生 onmessage 事件
- 当 onmessage 事件发生时,把已接收的数据推入 id 为 "result" 的元素中
; d+ f3 g6 N+ o* i* Q- ^
检测 Server-Sent 事件支持以下实例,我们编写了一段额外的代码来检测服务器发送事件的浏览器支持情况:
- if(typeof(EventSource)!=="undefined")
' c, q) u" B* b - {
( Z1 d4 p( A* i e- m - // 浏览器支持 Server-Sent
* @0 r5 q$ T. R - // 一些代码...... @$ C$ v; X9 l; r& Y$ L
- }
# O7 Y8 v# p# \ - else
# b- }' v4 c+ k4 w+ l - {4 c+ s9 }4 J% W4 a7 P$ t2 V
- // 浏览器不支持 Server-Sent..# ^; b L( M( N \: U* z& N: r! a
- }
复制代码 服务器端代码实例为了让上面的例子可以运行,您还需要能够发送数据更新的服务器(比如 PHP 和 ASP)。 服务器端事件流的语法是非常简单的。把 "Content-Type" 报头设置为 "text/event-stream"。现在,您可以开始发送事件流了。 - <?php . u$ [8 h6 V w4 W# F% e
- header('Content-Type: text/event-stream');
; ^) ^* D3 `' T/ `- m8 ~1 G* M3 T - header('Cache-Control: no-cache'); 1 i% a$ v7 o0 `4 t l \2 ~4 M
- : s, b6 B6 _( U) k+ w
- $time = date('r');
: Z% V5 S% M( J) _5 c& A - echo "data: The server time is: {$time}\n\n";
5 n- M- b; P+ [, c - flush();
& S! C) A& d" G - ?>
复制代码ASP 代码 (VB) (demo_sse.asp): - <%- P! f. V0 N" m4 H. \7 d+ n
- Response.ContentType="text/event-stream") h3 |5 @. l5 J+ v. b$ E( y6 P0 ~
- Response.Expires=-1' }0 [, I# g% i% C$ @' H7 k
- Response.Write("data: " & now())
* n5 O" l. F- E0 k- k" e2 H$ g0 y - Response.Flush() o$ C0 [+ B5 I( f$ k3 @8 |
- %>
复制代码代码解释: - 把报头 "Content-Type" 设置为 "text/event-stream"
- 规定不对页面进行缓存
- 输出发送日期(始终以 "data: " 开头)
- 向网页刷新输出数据) A' i% H, \" i: a$ v) Q. V
EventSource 对象在上面的例子中,我们使用 onmessage 事件来获取消息。不过还可以使用其他事件: 事件 | 描述 | | onopen | 当通往服务器的连接被打开 | | onmessage | 当接收到消息 | | onerror | 当发生错误 |
" ^+ A+ L& b5 u( M( L- f" x4 W" j/ q1 w
: W3 J0 N8 d t- o' \
+ h' Y9 U4 r2 P; i* K6 W# a" b! k# P9 L' S7 L
9 E# T! }! B& z$ {
5 C9 j% j( r3 K) X6 W
4 P0 k5 R1 q' o$ Z# @% w0 t& [/ I
- ^$ c- l, L$ e( N2 e) p) y0 S
1 m9 v9 ?9 i j, W% j [) ~8 X |