中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

html5之sse服務器發送事件EventSource的示例分析

發布時間:2021-07-26 14:26:55 來源:億速云 閱讀:165 作者:小新 欄目:web開發

這篇文章主要介紹html5之sse服務器發送事件EventSource的示例分析,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

Server-Sent Events使用

Server-Sent Events使用很簡單,通過EventSource 對象來接受服務器端消息。有如下事件:

  • onopen 當通往服務器的連接被打開

  • onmessage 當接收到消息

  • onerror 當發生錯誤

檢測 Server-Sent 事件支持

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

接收 Server-Sent 事件通知

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

服務器端代碼實例

<?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(); 
?>

鏈接事件和報錯事件都加上

if(typeof(EventSource)!=="undefined")
{
    var source=new EventSource("server.php");
    source.onopen=function()
    {
         console.log("Connection to server opened.");
    };
    source.onmessage=function(event)
    {

        document.getElementById("result").innerHTML+=event.data + "<br>";
    };
    source.onerror=function()
    {
        console.log("EventSource failed.");
    };
}
else
{
    document.getElementById("result").innerHTML="抱歉,你的瀏覽器不支持 server-sent 事件...";
}

我們會發現,控制臺打印如下:

html5之sse服務器發送事件EventSource的示例分析

不停的進入鏈接、和錯誤,詳情請點擊

那是因為php代碼只是簡單的echo,并沒有連續輸出,我們把上面php代碼做如下改進

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

$time = date('r'); 

  $i = 0;
  $c = $i + 100;
  while (++$i < $c) {
    echo "id: " . $i . "\n";
    echo "data: " . $time. ";\n\n";
    ob_flush();
    flush();
    sleep(1);
  }
?>

就不會出現不停錯誤了!

IE瀏覽器兼容解決方案

我們知道,IE瀏覽器并不支持EventSource,有如下解決方案:

引入

eventsource.min.js

就可以完美解決。可以查看其github地址:https://github.com/Yaffle/EventSource 結合nodejs使用也很方便,直接

npm install event-source-polyfill

以上是“html5之sse服務器發送事件EventSource的示例分析”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乌拉特中旗| 阿巴嘎旗| 丹江口市| 泰宁县| 扎囊县| 英吉沙县| 荥经县| 长沙市| 通州区| 腾冲县| 自治县| 石城县| 巴林左旗| 马龙县| 南安市| 北碚区| 陵川县| 开封县| 德保县| 龙江县| 渑池县| 日喀则市| 阳城县| 兴城市| 五常市| 龙口市| 浮梁县| 长沙市| 洛宁县| 平度市| 寻乌县| 马边| 屯留县| 格尔木市| 平乐县| 天长市| 焉耆| 远安县| 柏乡县| 鲁甸县| 杭州市|