ホームページ > ウェブフロントエンド > htmlチュートリアル > h5 sse サーバーを使用して EventSource イベントを送信する方法

h5 sse サーバーを使用して EventSource イベントを送信する方法

php中世界最好的语言
リリース: 2018-01-19 09:55:49
オリジナル
2431 人が閲覧しました

今回は、h5 の sse サーバーを使用して EventSourceイベントを送信する方法と、h5 の sse サーバーを使用して EventSource イベントを送信するための注意事項について説明します。以下は実際的なケースです。

はじめに

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

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

サーバー送信イベントは、EventSource オブジェクトを通じてサーバー側のメッセージを受け入れるのが非常に簡単です。次のイベントがあります:

onopen サーバーへの接続が開かれたとき

onmessage メッセージが受信されたとき

onerror エラーが発生したとき

サーバー送信イベントのサポートを検出

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();
?>
ログイン後にコピー

リンクイベントとエラーイベントが追加されました

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 事件...";
ログイン後にコピー

これらの事例を読んだ後は、方法を習得したと思います。さらに興味深い情報については、注目してください。 PHP 中国語 Web サイトの他の関連記事へ!

関連書籍:

HTML でテーブルのマウスドラッグソートを実装する方法

ie6-ie10 のさまざまな互換性問題を解決する方法

HTML で json データをフォーマットする方法

以上がh5 sse サーバーを使用して EventSource イベントを送信する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート