javascript 学习 EventSource 对象 碰到的一些问题??
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);
}
在浏览器中打开请求的 event_source.php 查看,如下图:
不理解 这里的 EventStream 是一个怎样的响应类型....,为什么 onmessage 方法一直接受不到任何数据(因为途中的EventStream 栏下 没有接收到任何信息...) , 这是怎么回事??我后台输出的是字符串,是否需要对该字符串做类型转换??
回复内容:
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);
}
在浏览器中打开请求的 event_source.php 查看,如下图:
不理解 这里的 EventStream 是一个怎样的响应类型....,为什么 onmessage 方法一直接受不到任何数据(因为途中的EventStream 栏下 没有接收到任何信息...) , 这是怎么回事??我后台输出的是字符串,是否需要对该字符串做类型转换??
因为你 echo 里面输出的文本内容格式不对。
每一次 echo 的内容,都必须是如下格式
field: value
field 可以是 data, event, id, retry 这四个中的任意一个
value 为数据有效载荷
你这里的例子,应该改为
echo "data: hello world\n\n";
参考资料:
https://www.mxgw.info/t/serve...
http://javascript.ruanyifeng....
https://developer.mozilla.org...
php里面没有加php标识符?
浏览器里面访问php文件, js肯定不能收到消息, 要建个html,浏览器里面访问html。
上一篇: 请教一个查询
下一篇: EM页面出现乱码无法正常使用
推荐阅读
-
JavaScript中的Object对象学习教程
-
JavaScript面向对象学习之类的创建,类的抽象代码实例讲解
-
JavaScript中的Object对象学习教程
-
我的javascript学习之路(二) 对象之定义
-
我的javascript学习之路(三) 对象之this
-
学习Object-C的碰到的一些问题或者说面试题
-
从零开始学习前端JAVASCRIPT — 3、JavaScript基础Math和Date对象的介绍
-
轻松学习 JavaScript——第 4 部分:函数中的 arguments 对象
-
【JavaScript学习】面向对象的程序设计(6):原型式继承
-
【JavaScript学习】面向对象的程序设计(3):原型链继承