您的位置:首页 > 其它

EventSource

2016-04-25 17:50 169 查看
从服务端接受事件,下面是html代码

function sendMessage(){
date_default_timezone_set("America/New_York");
header("Content-Type: text/event-stream\n\n");

$counter = rand(1, 10);
while (1) {
// Every second, sent a "ping" event.

echo "event: ping\n";
$curDate = date(DATE_ISO8601);
echo 'data: {"time": "' . $curDate . '"}';
echo "\n\n";

// Send a simple message at random intervals.

$counter--;

if (!$counter) {
echo 'data: This is a message at time ' . $curDate . "\n\n";
$counter = rand(1, 10);
}

ob_end_flush();
flush();
sleep(1);
}
}


View Code
注意服务端代码一定要设置
Content-Type为text/event-stream类型。


默认的事件会一直执行,所以你要手动的关闭

evtSource.close();


注意浏览器兼容性:

FeatureChromeFirefox (Gecko)Internet ExplorerOperaSafari
EventSource support96.0 (6.0)Not supported115
当然,可以在代码执行的时候判断是否兼容

if(typeof(EventSource) !== "undefined") {
// Yes! Server-sent events support!
// Some code.....
} else {
// Sorry! No server-sent events support..
}


注意返回的数据的形式

基本的形式如下:

data: My message\n\n

多行数据的话每一行前面都要data:之后加上一个\n,最后一行是两个\n。

data: first line\n
data: second line\n\n

上面返回的结果e.data是"first line\nsecond line"。接着
e.data.split('\n').join('')
来去掉所有\n之后组成的新的string

//split(分割符)通过分割符将string变成数组

//jion将数组链接成string

发送json数据使用格式如下:

data: {\n
data: "msg": "hello world",\n
data: "id": 12345\n
data: }\n\n

在客户端使用如下:

source.addEventListener('message', function(e) {
var data = JSON.parse(e.data);
console.log(data.id, data.msg);
}, false);


在发送的数据中添加id

可以为每次推送的信息中添加唯一的id(添加在信息开始处):

id: 12345\n
data: GOOG\n
data: 556\n\n

设置id可以让浏览器追踪最后一次被触发的事件,因为
e.lastEventId
属性存在。

控制重新链接的时间:浏览器会每3秒钟进行一次重新连接

可以在data之前设置"
retry:重新链接的毫秒数\n"来自定义重新连接的毫秒数
.

下面设置重新链接的时间是10秒:

retry: 10000\n
data: hello world\n\n

指定事件名称:

通过给事件名称可以让一个事件对象产生不同的时间类型。

"
event:事件名
"后面的data将和事件名相关联。

例如下面的服务器输出了三个事件类型,分别是:message,userlogon,update

data: {"msg": "First message"}\n\n
event: userlogon\n
data: {"username": "John123"}\n\n
event: update\n
data: {"username": "John123", "emotion": "happy"}\n\n

客户端的监听是:

source.addEventListener('message', function(e) {
var data = JSON.parse(e.data);
console.log(data.msg);
}, false);

source.addEventListener('userlogon', function(e) {
var data = JSON.parse(e.data);
console.log('User login:' + data.username);
}, false);

source.addEventListener('update', function(e) {
var data = JSON.parse(e.data);
console.log(data.username + ' is now ' + data.emotion);
}, false);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: