首頁 > 後端開發 > php教程 > javascript 學習 EventSource 物件 碰到的一些問題? ?

javascript 學習 EventSource 物件 碰到的一些問題? ?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-09-19 09:16:30
原創
1532 人瀏覽過

<code>javascript:
var e = new EventSource('test.php');
e.onopen = function(){
  console.log('你创建了一个服务器长连接!');
};

e.onmessage = function(event){
  var e = event || window.event;
  console.log('接受到来自服务器的消息: ' + event.data);
}

e.onerror = function(event){
  console.log('链接发生错误,当前链接状态: ' +  event.readyState);
}

PHP:
header('content-type:text/event-stream');
header('cache-control:no-cache');
while (true)
 {
   echo 'hello world';
   ob_flush();
   flush();
   sleep(1);
 }
 </code>
登入後複製
登入後複製

在瀏覽器中開啟請求的 event_source.php 查看,如下圖:

javascript 學習 EventSource 物件 碰到的一些問題? ?

不理解 這裡的 EventStream 是怎樣的回應類型....,為什麼 onmessage 方法一直接受不到任何資料(因為途中的EventStream 欄下 沒有接收到任何資訊...) , 這是怎麼回事? ?我後台輸出的是字串,是否需要對該字串做型別轉換? ?

回覆內容:

<code>javascript:
var e = new EventSource('test.php');
e.onopen = function(){
  console.log('你创建了一个服务器长连接!');
};

e.onmessage = function(event){
  var e = event || window.event;
  console.log('接受到来自服务器的消息: ' + event.data);
}

e.onerror = function(event){
  console.log('链接发生错误,当前链接状态: ' +  event.readyState);
}

PHP:
header('content-type:text/event-stream');
header('cache-control:no-cache');
while (true)
 {
   echo 'hello world';
   ob_flush();
   flush();
   sleep(1);
 }
 </code>
登入後複製
登入後複製

在瀏覽器中開啟請求的 event_source.php 查看,如下圖:

javascript 學習 EventSource 物件 碰到的一些問題? ?

不理解 這裡的 EventStream 是怎樣的回應類型....,為什麼 onmessage 方法一直接受不到任何資料(因為途中的EventStream 欄下 沒有接收到任何資訊...) , 這是怎麼回事? ?我後台輸出的是字串,是否需要對該字串做型別轉換? ?

因為你 echo 裡面輸出的文字內容格式不對。

每一次 echo 的內容,都必須是如下格式

<code>field: value
</code>
登入後複製

field 可以是 data, event, id, retry 這四個中的任一個
value 為資料有效載荷

你這裡的例子,應該改為

<code>echo "data: hello world\n\n";
</code>
登入後複製

參考資料:

  • https://www.mxgw.info/t/serve...

  • http://javascript.ruanyifeng....

  • https://developer.mozilla.org...


php裡面沒有加php標識符?
瀏覽器裡面訪問php文件, js一定不能收到訊息, 要建個html,瀏覽器裡面訪問html。

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
JavaScript鉤子函數是什麼?
來自於 1970-01-01 08:00:00
0
0
0
怎麼實作 JavaScript點與圓的位置關係
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板