首页前端开发HTML带你认识HTML5中的WebSocket

带你认识HTML5中的WebSocket

时间2024-01-22 18:39:29发布访客分类HTML浏览317
导读:收集整理的这篇文章主要介绍了带你认识HTML5中的WebSocket,觉得挺不错的,现在分享给大家,也给大家做个参考。认识 HTML5 的 WebSocket@H_126_1@在 HTML5 规范中,我最喜欢的Web技术就是正迅速变得流行的...
收集整理的这篇文章主要介绍了带你认识HTML5中的WebSocket,觉得挺不错的,现在分享给大家,也给大家做个参考。认识 HTML5 的 WebSocket@H_126_1@

在 HTML5 规范中,我最喜欢的Web技术就是正迅速变得流行的 WebSocket API。WebSocket 提供了一个受欢迎的技术,以替代我们过去几年一直在用的Ajax技术。这个新的API提供了一个方法,从客户端使用简单的语法有效地推动消息到服务器。让我们看一看 HTML5 的 WebSocket API:它可用于客户端、服务器端。而且有一个优秀的第三方API,名为Socket.IO。

一、HTML5 中的 WebSocket API 是个什么东东?

WebSocket API是下一代客户端-服务器的异步通信方法。该通信取代了单个的TCP套接字,使用ws或wss协议,可用于任意的客户端和服务器程序。WebSocket目前由W3C进行标准化。WebSocket已经受到Firefox 4、Chrome 4、opera 10.70以及Safari 5等浏览器的支持。

WebSocket API最伟大之处在于服务器和客户端可以在给定的时间范围内的任意时刻,相互推送信息。WebSocket并不限于以Ajax(或Xhr)方式通信,因为Ajax技术需要客户端发起请求,而WebSocket服务器和客户端可以彼此相互推送信息;XHR受到域的限制,而WebSocket允许跨域通信。

Ajax技术很聪明的一点是没有设计要使用的方式。WebSocket为指定目标创建,用于双向推送消息。

二、HTML5 中的 WebSocket API 的用法

只专注于客户端的API,因为每个服务器端语言有自己的API。下面的代码片段是打开一个连接,为连接创建事件监听器,断开连接,消息时间,发送消息返回到服务器,关闭连接。

代码如下:

// 创建一个Socket实例VAR socket = new WebSocket('ws://localhost:8080');
// 打开Socket socket.onoPEn = function(event){
      // 发送一个初始化消息  socket.send('I am the client and I\'m listening!');
  // 监听消息  socket.onmessage = function(event){
        console.LOG('Client received a message',event);
  }
    ;
  // 监听Socket的关闭  socket.onclose = function(event){
        console.log('Client notified socket has closed',event);
  }
    ;
  // 关闭Socket....   //socket.close()}
    ;
    

让我们来看看上面的初始化片段。参数为URL,ws表示WebSocket协议。onopen、onclose和onmessage方法把事件连接到Socket实例上。每个方法都提供了一个事件,以表示Socket的状态。

onmessage事件提供了一个data属性,它可以包含消息的Body部分。消息的Body部分必须是一个字符串,可以进行序列化/反序列化操作,以便传递更多的数据。

WebSocket的语法非常简单,使用WebSockets是难以置信的容易& hellip; & hellip; 除非客户端不支持WebSocket。IE浏览器目前不支持Websocket通信。如果你的客户端不支持WebSocket通信,下面有几个后备方案供你使用:

Flash技术 & mdash; & mdash; Flash可以提供一个简单的替换。 使用Flash最明显的缺点是并非所有客户端都安装了Flash,而且某些客户端,如iPhone/iPad,不支持Flash。

AJAX Long-Polling技术 & mdash; & mdash; 用AJAX的long-polling来模拟WebSocket在业界已经有一段时间了。它是一个可行的技术,但它不能优化发送的信息。也就是说,它是一个解决方案,但不是最佳的技术方案。

由于目前的IE等浏览器不支持WebSocket,要提供WebSocket的@R_360_1988@、返回传输、在服务器端使用一个统一的API,那么该怎么办呢?幸运的是,Guillermo Rauch创建了一个Socket.IO技术。

三、带Socket.IO的WebSocket

Socket.IO是Guillermo Rauch创建的WebSocket API,Guillermo Rauch是LearnBoost公司的首席技术官以及LearnBoost实验室的首席科学家。Socket.IO使用检测功能来判断是否建立WebSocket连接,或者是AJAX long-polling连接,或Flash等。可快速创建实时的应用程序。Socket.IO还提供了一个NodeJS API,它看起来非常像客户端API。

【相关推荐】

1. 免费h5在线视频教程

2. HTML5 完整版手册

3. php.cn原创HTML5视频教程

4. h5Canvas绘制五星红旗的实例讲解

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: 详解HTML5中的WebSocket及实例代...下一篇:HTML5不支持标签和新增标签详解猜你在找的html5相关文章 关于移动端h5开发相关内容总结2022-05-17html5教程-学表单的第二天2018-12-10html5教程-HTML5浏览器支持2018-12-10html5教程-HTML5智能表单2018-12-10html5教程-微信H5使用resLoader实现加载页效果2018-12-10html5教程-day01-初级-JS0-热身运动JS入门教程2018-12-10html5教程-html5shiv.js和respond.min.js2018-12-10html5教程-不同浏览器对于html5 audio标签和音频格式的兼容性2018-12-10html5教程-使用Html5实现手风琴案例2018-12-10html5教程-html5笔记2018-12-10 其他相关热搜词更多phpjavapython程序员load

若转载请注明出处: 带你认识HTML5中的WebSocket
本文地址: https://pptw.com/jishu/583237.html
H5与传统html的区别 H5制作一个注册页面的代码实例

游客 回复需填写必要信息