• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > H5的之sse服务器发送事件EventSource详解

H5的之sse服务器发送事件EventSource详解

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含EventSource,html5,服务器等相关知识,匿名希望在学习及工作中可以帮助到您
这次给大家带来H5的之sse服务器发送事件EventSource详解,sse服务器发送事件EventSource的注意事项有哪些,下面就是实战案例,一起来看一下。

前言

我前面文章讲过数据大屏,里面的数据时时更新。还有时时更新的股票数据,Facebook/Twitter 更新、估价更新、新的博文、赛事结果等等,都需要数据时时更新。之前我们一般都是请求服务器,看看有没有可以更新的数据。html5提供了Server-Sent Events方法,通过服务器发送事件,更新能够自动到达。

Server-Sent Events使用

Server-Sent Events使用很简单,通过EventSource 对象来接受服务器端消息。有如下事件:

  • onopen 当通往服务器的连接被打开

  • onmessage 当接收到消息

  • onerror 当发生错误

检测 Server-Sent 事件支持

if(typeof(EventSource)!=="undefined")
{
  // 浏览器支持 Server-Sent
  // 一些代码.....
}
else
{
// 浏览器不支持 Server-Sent..
}

接收 Server-Sent 事件通知

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

服务器端代码实例

<?php 
header('Content-Type: text/event-stream'); 
header('Cache-Control: no-cache'); 
$time = date('r'); 
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代码只是简单的echo,并没有连续输出,我们把上面php代码做如下改进

<?php 
header('Content-Type: text/event-stream'); 
header('Cache-Control: no-cache'); 
$time = date('r'); 
  $i = 0;
  $c = $i + 100;
  while (++$i < $c) {
    echo "id: " . $i . "\n";
    echo "data: " . $time. ";\n\n";
    ob_flush();
    flush();
    sleep(1);
  }
?>

就不会出现不停错误了!

IE浏览器兼容解决方案

我们知道,IE浏览器并不支持EventSource,有如下解决方案:

引入

eventsource.min.js

就可以完美解决。可以查看其github地址:https://github.com/Yaffle/EventSource 结合nodejs使用也很方便,直接

npm install event-source-polyfill

相信看了本文案例你已经掌握了方法,更多精彩请关注微课江湖其它相关文章!

推荐阅读:

H5实现可缩放的时钟动画

前缀data-属性和dataset的使用方法

以上就是H5的之sse服务器发送事件EventSource详解的详细内容,更多请关注微课江湖其它相关文章!

您可能想查找下面的文章:

  • H5的之sse服务器发送事件EventSource详解
  • HTML 5 event-source 标签是否违背了自定义标签才使用短横线的约定?

相关文章

  • 2018-12-03phonegap创建联系人详解
  • 2017-08-06html5 Canvas画图教程(2)—画直线与设置线条的样式如颜色/端点/交汇点
  • 2018-12-03H5页面在iPhoneX显示的适配问题
  • 2017-08-06html5 拖拽上传图片实例演示
  • 2017-08-06html5 viewport使用方法示例详解
  • 2017-08-06HTML5 Canvas鼠标与键盘事件demo示例
  • 2018-12-03HTML5混合开发二维码扫描以及调用本地摄像头实例教程
  • 2017-08-06Html5 postMessage实现跨域消息传递
  • 2018-12-03Html5中内容安全策略(CSP)
  • 2018-12-03HTML5 data-* 自定义属性实例分享

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 使用css如何制作时间ICON方法实践
    • HTML5之SVG 2D入门9—蒙板及mask元素介绍与应用
    • 逼真的HTML5树叶飘落动画
    • 使用javascript的模块加载器
    • HTML5声音录制和播放功能的实现
    • 分享一个HTML5Plus移动应用
    • 详细介绍HTML5游戏开发5条建议及开发工具分享
    • 两种常用编程的比较 声明式和命令式
    • 用HTML5制作一个简单的桌球游戏的教程_html5教程技巧
    • HTML5之WebGL 3D概述(上)—WebGL原生开发开启网页3D渲染新时代_html5教程技巧

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有