搜索
首页web前端H5教程浅析HTML5的WebSocket与服务器推送事件_html5教程技巧

WebSockets

Web Sockets 是用于 Web 应用程序的新一代双向通信技术,运行在单一套接字之上,它通过 JavaScript 接口暴漏在 HTML5 兼容的浏览器中。

一旦取得 Web 服务器上的 Web Socket 连接之后,就可以通过调用 send() 方法从浏览器发送数据到服务器上,通过 onmessage 事件处理程序从服务器接收数据到浏览器中。

下面是创建一个新的 WebSocket 对象的 API。

JavaScript Code复制内容到剪贴板
  1. var Socket = new WebSocket(url, [protocal] );  

第一个参数 url 用于指定要连接的 URL。第二个属性 - 端口是可选的,如果提供,就会指定一个服务器必须支持连接成功的子协议。

WebSocket 属性
下面是 WebSocket 对象的属性。假定我们已经创建了上述的 Socket 对象:

属性 描述
Socket.readyState
属性 描述
Socket.readyState

只读属性readyState表示连接的状态。有以下取值:

  1. 0 表示连接尚未建立。

  2. 1 表示连接已建立,可以进行通信。

  3. 2 表示连接正在进行关闭握手。

  4. 3 表示连接已经关闭或者连接不能打开。

Socket.bufferedAmount

只读属性bufferedAmount表示已经使用 send() 方法排队的 URF-8 文本字节数。

只读属性
readyState表示连接的状态。有以下取值:
0 表示连接尚未建立。
事件 事件处理程序 描述
open Socket.onopen 建立 socket 连接时触发这个事件。
message Socket.onmessage 客户端从服务器接收数据时触发。
error Socket.onerror 连接发生错误时触发。
close Socket.onclose 连接被关闭时触发。

  • 1 表示连接已建立,可以进行通信。
  • 2 表示连接正在进行关闭握手。
    方法 描述
    Socket.send()

    send(data) 方法使用连接传输数据。

    Socket.close()

    close() 方法用于终止任何现有连接。

  • 3 表示连接已经关闭或者连接不能打开。
  • Socket.bufferedAmount 只读属性bufferedAmount表示已经使用 send() 方法排队的 URF-8 文本字节数。
    WebSocket 事件下面是 WebSocket 对象相关的事件。假定我们已经创建了上述的 Socket 对象: WebSocket 方法下面是 WebSocket 对象相关的方法。假定我们已经创建了上述的 Socket 对象:
    方法 描述
    Socket.send() send(data) 方法使用连接传输数据。
    Socket.close() close() 方法用于终止任何现有连接。

    服务器推送事件
    传统的 Web 应用程序生成发送到 Web 服务器端的事件。比如,点击一个链接会从服务器请求一个新页面。

    这种从 Web 浏览器到 Web 服务器的时间类型可以称作客服端事件。

    随着 HTML5 的出现,WHATWG Web Applications 1.0 引入了一个从 Web 服务器到 Web 浏览器的事件流,被称作服务器推送事件(SSE)。使用 SSE 可以不停的将 DOM 事件推送到用户的浏览器中。

    这个事件流方法会打开一个到服务器的持久连接,新消息可用时发送数据到客户端,从而不再需要持续的轮询。

    SSE Web 应用程序
    要在 Web 应用程序中使用服务器推送事件,我们需要给文档添加一个 元素。

    元素的 src 属性应该指向一个 URL,这个 URL 应该提供一个 HTTP 持久连接用于发送包含事件的数据流。

    这个 URL 将会指向一个持续发送事件数据的 PHP,PERL 或者任意 Python 脚本。下面是一个简单的期望获得服务器时间的 Web 应用程序示例。

    XML/HTML Code复制内容到剪贴板
    1. HTML>  
    2. html>  
    3. head>  
    4. script type="text/javascript">  
    5. /* Define event handling logic here */   
    6. script>  
    7. head>  
    8. body>  
    9. div id="sse">  
    10.    eventsource src="/cgi-bin/ticker.cgi" />  
    11. div>  
    12. div id="ticker">  
    13.    TIME>  
    14. div>  
    15. body>  
    16. html>  

    SSE 服务器端脚本
    服务器端脚本应该发送 Content-type 头指定类型为 text/event-stream,如下所示:


    复制代码
    代码如下:
    print "Content-Type: text/event-streamnn";

    设置 Content-type 之后,服务器端脚本将发送一个后面紧跟事件名称的 Event: 标签。下面的示例将会发送一个以换行符结束的 Server-Time 作为事件名称。


    复制代码
    代码如下:
    print "Event: server-timen";

    最后一步是使用 Data: 标签发送事件数据,紧随其后的是以换行符结束的整数字符串值,如下所示:


    复制代码
    代码如下:
    $time = localtime();
    print "Data: $timen";

    下面是用 perl 编写的完整 ticker.cgi:


    复制代码
    代码如下:

    #!/usr/bin/perl
    print "Content-Type: text/event-streamnn";
    while(true){
    print "Event: server-timen";
    $time = localtime();
    print "Data: $timen";
    sleep(5);

    处理服务器推送事件
    让我们修改一下我们的 Web 应用程序来处理服务器推送时间。下面是最终示例:

    XML/HTML Code复制内容到剪贴板
    1. HTML>  
    2. html>  
    3. >  
    4. 脚本 类型="text/ javascript">  
    5.    document.getElementsByTagName("eventsource")[0]。   
    6.             addEventListener("服务器时间", eventHandler, false);   
    7.    函数 eventHandler(event)   
    8.    {   
    9.        //服务器发送的警报时间   
    10.        document.querySelector('#ticker').innerHTML = 事件.data;   
    11.   
    12.    }   
    13. 脚本>  
    14. >  
    15. 身体>  
    16. div id="sse" >  
    17.    事件源 src="/cgi -bin/ticker.cgi" />  
    18. div>  
    19. div id=“代码”  姓名=“股票代码”>  
    20.    [时间]   
    21. div>  
    22. 身体>  
    23. html>  

    在测试服务器主动活动之前,建议您确保您的 Web 浏览器支持这一概念。

    声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    H5:网络内容和设计的未来H5:网络内容和设计的未来May 01, 2025 am 12:12 AM

    H5(HTML5)将通过新元素和API提升网页内容和设计。1)H5增强了语义化标记和多媒体支持。2)它引入了Canvas和SVG,丰富了网页设计。3)H5的工作原理是通过新标签和API扩展HTML功能。4)基本用法包括使用创建图形,高级用法涉及WebStorageAPI。5)开发者需注意浏览器兼容性和性能优化。

    H5:网络开发的新功能和功能H5:网络开发的新功能和功能Apr 29, 2025 am 12:07 AM

    H5带来了多项新功能和能力,极大提升了网页的互动性和开发效率。1.语义化标签如、增强了SEO。2.多媒体支持通过和标签简化了音视频播放。3.Canvas绘图提供了动态图形绘制工具。4.本地存储通过localStorage和sessionStorage简化了数据存储。5.地理位置API便于开发基于位置的服务。

    H5:HTML5的关键改进H5:HTML5的关键改进Apr 28, 2025 am 12:26 AM

    HTML5带来了五个关键改进:1.语义化标签提升了代码清晰度和SEO效果;2.多媒体支持简化了视频和音频嵌入;3.表单增强简化了验证;4.离线与本地存储提高了用户体验;5.画布与图形功能增强了网页的可视化效果。

    HTML5:标准及其对Web开发的影响HTML5:标准及其对Web开发的影响Apr 27, 2025 am 12:12 AM

    HTML5的核心特性包括语义化标签、多媒体支持、离线存储与本地存储、表单增强。1.语义化标签如、等,提升代码可读性和SEO效果。2.和标签简化多媒体嵌入。3.离线存储和本地存储如ApplicationCache和LocalStorage,支持无网络运行和数据存储。4.表单增强引入新输入类型和验证属性,简化处理和验证。

    H5代码示例:实际应用和教程H5代码示例:实际应用和教程Apr 25, 2025 am 12:10 AM

    H5提供了多种新特性和功能,极大地增强了前端开发的能力。1.多媒体支持:通过和元素嵌入媒体,无需插件。2.画布(Canvas):使用元素动态渲染2D图形和动画。3.本地存储:通过localStorage和sessionStorage实现数据持久化存储,提升用户体验。

    H5和HTML5之间的连接:相似性和差异H5和HTML5之间的连接:相似性和差异Apr 24, 2025 am 12:01 AM

    H5和HTML5是不同的概念:HTML5是HTML的一个版本,包含新元素和API;H5是基于HTML5的移动应用开发框架。HTML5通过浏览器解析和渲染代码,H5应用则需要容器运行并通过JavaScript与原生代码交互。

    H5代码的基础:密钥元素及其目的H5代码的基础:密钥元素及其目的Apr 23, 2025 am 12:09 AM

    HTML5的关键元素包括、、、、、等,用于构建现代网页。1.定义头部内容,2.用于导航链接,3.表示独立文章内容,4.组织页面内容,5.展示侧边栏内容,6.定义页脚,这些元素增强了网页的结构和功能性。

    HTML5和H5:了解常见用法HTML5和H5:了解常见用法Apr 22, 2025 am 12:01 AM

    HTML5和H5没有区别,H5是HTML5的简称。1.HTML5是HTML的第五个版本,增强了网页的多媒体和交互功能。2.H5常用于指代基于HTML5的移动网页或应用,适用于各种移动设备。

    See all articles

    热AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智能驱动的应用程序,用于创建逼真的裸体照片

    AI Clothes Remover

    AI Clothes Remover

    用于从照片中去除衣服的在线人工智能工具。

    Undress AI Tool

    Undress AI Tool

    免费脱衣服图片

    Clothoff.io

    Clothoff.io

    AI脱衣机

    Video Face Swap

    Video Face Swap

    使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

    热工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神级代码编辑软件(SublimeText3)

    Dreamweaver CS6

    Dreamweaver CS6

    视觉化网页开发工具

    EditPlus 中文破解版

    EditPlus 中文破解版

    体积小,语法高亮,不支持代码提示功能

    WebStorm Mac版

    WebStorm Mac版

    好用的JavaScript开发工具

    ZendStudio 13.5.1 Mac

    ZendStudio 13.5.1 Mac

    功能强大的PHP集成开发环境