ホームページ  >  記事  >  ウェブフロントエンド  >  HTML5 の sse サーバーによって送信される EventSource の概要

HTML5 の sse サーバーによって送信される EventSource の概要

巴扎黑
巴扎黑オリジナル
2017-09-02 10:00:032407ブラウズ

この記事では、HTML5 での sse サーバー送信イベントの EventSource の導入について主に紹介します。興味があれば、さらに詳しく学ぶことができます。

ビッグデータについて話しました。前回の記事の画面とその中のデータ 随時更新します。また、随時更新される株式データ、Facebook/Twitter の更新、評価の更新、新しいブログの投稿、イベントの結果など、すべてデータを随時更新する必要があります。以前は、更新できるデータがあるかどうかをサーバーにリクエストするのが一般的でした。 HTML5 は、サーバー経由でイベントを送信し、更新を自動的に受信できるサーバー送信イベント メソッドを提供します。

サーバー送信イベントの使用法

サーバー送信イベントは、EventSource オブジェクトを通じてサーバー側のメッセージを受け入れるのが非常に簡単です。次のインシデント:サーバーへの接続が開かれたときのponopen inmessage、メッセージが受信されたときサーバー送信イベント通知

if(typeof(EventSource)!=="undefined")
{
  // 浏览器支持 Server-Sent
  // 一些代码.....
}
else
{
// 浏览器不支持 Server-Sent..
}
  • サーバー側のコード例

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

  • リンクイベントとエラーイベントが追加されます
<?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(); 
?>

us 次のようにコンソールに表示されることがわかります。 :


リンクとエラーを入力し続けてください。詳細については、クリックしてください

それは、php コードが単なるエコーであり、継続的に出力されないためです。上記の php コードを次のように改善しました

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 事件...";
}

いいえ。さらにエラーが!

IE ブラウザと互換性のあるソリューション

IE ブラウザが EventSource をサポートしていないことはわかっていますが、次の解決策があります:


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

$time = date(&#39;r&#39;); 

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

の導入は完璧なソリューションです。 github アドレスを確認できます: https://github.com/Yaffle/EventSource

eventsource.min.js

だけで、nodejs と一緒に使用することも非常に便利です。

以上がHTML5 の sse サーバーによって送信される EventSource の概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。