HTML5 服務(wù)器發(fā)送事件(Server-Sent Events)

HTML5 服務(wù)器發(fā)送事件(SSE: server-sent event)允許網(wǎng)頁獲得來自服務(wù)器的更新纸兔。


Server-Sent 事件 - 單向消息傳遞

Server-Sent 事件指的是網(wǎng)頁自動(dòng)獲取來自服務(wù)器的更新乌叶。

以前也可能做到這一點(diǎn),前提是網(wǎng)頁不得不詢問是否有可用的更新撕阎。通過服務(wù)器發(fā)送事件,更新能夠自動(dòng)到達(dá)碌补。
例子:Facebook/Twitter 更新虏束、估價(jià)更新、新的博文厦章、賽事結(jié)果等镇匀。

接收 Server-Sent 事件通知

EventSource 對(duì)象用于接收服務(wù)器發(fā)送事件通知:

var source=new EventSource("demo_sse.php");
source.onmessage=function(event)
{
    document.getElementById("result").innerHTML+=event.data + "<br>";
};

實(shí)例解析:

  • 創(chuàng)建一個(gè)新的 EventSource 對(duì)象,然后規(guī)定發(fā)送更新的頁面的 URL(本例中是 "demo_sse.php")
  • 每接收到一次更新闷袒,就會(huì)發(fā)生 onmessage 事件
  • 當(dāng) onmessage 事件發(fā)生時(shí)坑律,把已接收的數(shù)據(jù)推入 id 為 "result" 的元素中

檢測(cè) Server-Sent 事件支持

if(typeof(EventSource)!=="undefined")
{
  // 瀏覽器支持 Server-Sent
  // 一些代碼.....
}
else
{
// 瀏覽器不支持 Server-Sent..
}

服務(wù)器端代碼實(shí)例

為了讓上面的例子可以運(yùn)行,您還需要能夠發(fā)送數(shù)據(jù)更新的服務(wù)器(比如 PHP 和 ASP)。
服務(wù)器端事件流的語法是非常簡(jiǎn)單的晃择。把 "Content-Type" 報(bào)頭設(shè)置為 "text/event-stream"〖街担現(xiàn)在,您可以開始發(fā)送事件流了宫屠。

<?php 
header('Content-Type: text/event-stream'); 
header('Cache-Control: no-cache'); 

$time = date('r'); 
echo "data: The server time is: {$time}\n\n"; 
flush(); 
?>

ASP 代碼 (VB) (demo_sse.asp):

<%
    Response.ContentType="text/event-stream"
    Response.Expires=-1
    Response.Write("data: " & now())
    Response.Flush()
%>

代碼解釋:

  • 把報(bào)頭 "Content-Type" 設(shè)置為 "text/event-stream"
  • 規(guī)定不對(duì)頁面進(jìn)行緩存
  • 輸出發(fā)送日期(始終以 "data: " 開頭)
  • 向網(wǎng)頁刷新輸出數(shù)據(jù)

EventSource 對(duì)象

在上面的例子中列疗,我們使用 onmessage 事件來獲取消息。不過還可以使用其他事件:

事件 描述
onopen 當(dāng)通往服務(wù)器的連接被打開
onmessage 當(dāng)接收到消息
onerror 當(dāng)發(fā)生錯(cuò)誤
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末浪蹂,一起剝皮案震驚了整個(gè)濱河市抵栈,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌坤次,老刑警劉巖古劲,帶你破解...
    沈念sama閱讀 217,734評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異缰猴,居然都是意外死亡产艾,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門滑绒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來闷堡,“玉大人,你說我怎么就攤上這事疑故「芾溃” “怎么了?”我有些...
    開封第一講書人閱讀 164,133評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵纵势,是天一觀的道長(zhǎng)踱阿。 經(jīng)常有香客問我,道長(zhǎng)吨悍,這世上最難降的妖魔是什么扫茅? 我笑而不...
    開封第一講書人閱讀 58,532評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮育瓜,結(jié)果婚禮上葫隙,老公的妹妹穿的比我還像新娘。我一直安慰自己躏仇,他們只是感情好恋脚,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,585評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著焰手,像睡著了一般糟描。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上书妻,一...
    開封第一講書人閱讀 51,462評(píng)論 1 302
  • 那天船响,我揣著相機(jī)與錄音,去河邊找鬼。 笑死见间,一個(gè)胖子當(dāng)著我的面吹牛聊闯,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播米诉,決...
    沈念sama閱讀 40,262評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼菱蔬,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了史侣?” 一聲冷哼從身側(cè)響起拴泌,我...
    開封第一講書人閱讀 39,153評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎惊橱,沒想到半個(gè)月后蚪腐,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,587評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡税朴,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,792評(píng)論 3 336
  • 正文 我和宋清朗相戀三年削茁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掉房。...
    茶點(diǎn)故事閱讀 39,919評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖慰丛,靈堂內(nèi)的尸體忽然破棺而出卓囚,到底是詐尸還是另有隱情,我是刑警寧澤诅病,帶...
    沈念sama閱讀 35,635評(píng)論 5 345
  • 正文 年R本政府宣布哪亿,位于F島的核電站,受9級(jí)特大地震影響贤笆,放射性物質(zhì)發(fā)生泄漏蝇棉。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,237評(píng)論 3 329
  • 文/蒙蒙 一芥永、第九天 我趴在偏房一處隱蔽的房頂上張望篡殷。 院中可真熱鬧,春花似錦埋涧、人聲如沸板辽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽劲弦。三九已至,卻和暖如春醇坝,著一層夾襖步出監(jiān)牢的瞬間邑跪,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留画畅,地道東北人砸琅。 一個(gè)月前我還...
    沈念sama閱讀 48,048評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像夜赵,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子摊腋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,864評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容