首頁 web前端 html教學 HTML 5 伺服器傳送事件

HTML 5 伺服器傳送事件

Dec 27, 2016 pm 02:43 PM

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

Server-Sent 事件指的是網頁自動取得來自伺服器的更新。

以前也可能做到這一點,前提是網頁必須詢問是否有可用的更新。透過伺服器發送事件,更新能夠自動到達。

範例:Facebook/Twitter 更新、估價更新、新的部落格文章、賽事結果等。

瀏覽器支援

所有主流瀏覽器均支援伺服器發送事件,除了 Internet Explorer。

接收Server-Sent 事件通知

EventSource 物件用於接收伺服器發送事件通知:

實例

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

範例解釋:

建立一個新的EventSource 對象,然後規定發送更新的頁面的URL(本例中的網址是"demo_sse.php")

每接收到一次更新,就會發生onmessage 事件

當onmessage 事件發生時,把已接收的資料推入id 為"result" 的元素中

檢測Server-Sent 事件支援

在上面的TIY 實例中,我們編寫了一段額外的程式碼來偵測伺服器傳送事件的瀏覽器支援情況:

if(typeof(EventSource)!=="undefined") { // Yes! Server-sent events support! // Some code..... } else { // Sorry! No server-sent events support.. }
登入後複製

伺服器端程式碼實例

為了讓上面的範例可以運行,您還需要能夠傳送資料更新的伺服器(如 PHP 和ASP)。

伺服器端事件流的語法是非常簡單的。把 "Content-Type" 標頭設定為 "text/event-stream"。現在,您可以開始發送事件流了。

PHP 程式碼(demo_sse.php):

<?php header(&#39;Content-Type: text/event-stream&#39;); header(&#39;Cache-Control: no-cache&#39;); $time = date(&#39;r&#39;); 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() %>
登入後複製

程式碼解釋:

把標頭"Content-Type" 設定為"text/event-stream"

把報頭"規定不對頁面進行快取

輸出發送日期(總是以"data: " 開頭)

向網頁刷新輸出資料

EventSource 物件

在上面的例子中,我們使用onmessage 事件來取得訊息。不過也可以使用其他事件:

事件

描述

onopen    當通往伺服器的連線開啟   

 

 以上就是HTML 5 伺服器發送事件的內容,更多相關內容請關注PHP中文網(www.php.cn)!


本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

HTML 中的表格邊框 HTML 中的表格邊框 Sep 04, 2024 pm 04:49 PM

HTML 中的表格邊框

HTML 中的巢狀表 HTML 中的巢狀表 Sep 04, 2024 pm 04:49 PM

HTML 中的巢狀表

HTML 左邊距 HTML 左邊距 Sep 04, 2024 pm 04:48 PM

HTML 左邊距

HTML 表格佈局 HTML 表格佈局 Sep 04, 2024 pm 04:54 PM

HTML 表格佈局

在 HTML 中移動文字 在 HTML 中移動文字 Sep 04, 2024 pm 04:45 PM

在 HTML 中移動文字

HTML 有序列表 HTML 有序列表 Sep 04, 2024 pm 04:43 PM

HTML 有序列表

您如何在PHP中解析和處理HTML/XML? 您如何在PHP中解析和處理HTML/XML? Feb 07, 2025 am 11:57 AM

您如何在PHP中解析和處理HTML/XML?

HTML onclick 按鈕 HTML onclick 按鈕 Sep 04, 2024 pm 04:49 PM

HTML onclick 按鈕

See all articles