笔者近期在公司的项目中渐渐的接触了一些比较高级的业务逻辑处理,其中比较有意思的地方就是前端接受后台给与的推送问题。

一般前端与后端的交互主要是使用ajax进行异步操作调用交互,比较有趣的是这种交互方式一般都是单项交互的--

-及前端给后端发出请求后端接受请求后执行操作,即便前端可以接受后端给予的返回值,但是与后端交互的主动权始终是放在前端手里面。

而这样就会遇到两个有意思的问题--

1.前端如果调用的接口后端操作事件过长可能会导致返回操作响应时间过长,如果此时用户单击其他页面的时候就会导致返回操作无法正常解决。

2.如果后端有什么比较重要的问题需要推送给前端消息,这个时候前端是无法接收到的。

面对这两个问题的主流解决办法分别为
针对第一条我们会给整个页面做一个加载中的动画并且锁定住整个页面从而强迫用户等待到整个后端返回值结束后再将页面解锁。

而对于第二点我们就要引入我们今天所讲的websocket这个概念。


一.什么是websocket

websocket协议在2008年诞生,2011年成为国际标准。所有浏览器都已经支持了。

它的最大特点就是,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真正的双向平等对话,属于服务器推送技术的一种。

而他与常规的ajax最大的不同在于他可以双向接受和发送

一.websocket的简单使用

对于我们前端来说websocket的使用方式非常简单,协议标识符是ws(如果加密,则为wss),服务器网址就是 URL。我们只需要自己定义一个ws服务就可以了

代码如下

var ws = new WebSocket("URL路径");

ws.onopen = function(evt) {
console.log("打开成功");
ws.send("Hello WORD!");
}; ws.onmessage = function(evt) {
console.log( "Received Message: " + evt.data);
ws.close();
}; ws.onclose = function(evt) {
console.log("服务关闭");
};

如以上代码所示我们成功的创建了一个简单的名字为WS的websocket服务并且想后台定义的路径中发送了一条hello word的简讯并且会在接收到推送的时候打印Received Message

在你的ws服务打开以后会在前端的内一直处于挂起状态,由于现在框架横行,当你的框架或者说前端项目经过node编译或者运行时候你可以把ws服务写在所有页面的模板中就可以让项目只要处于被打开状态就能一直运行

这个时候你需要写接受推送消息即可,判断后端给你推送消息的类型并且做出相应的操作,完全不需要有ajax异步操作等待返回值或者返回值后自己操作时间太长而让用户等待太久的烦恼。而这一技术现在也普遍的用在了

在线聊天室和一些需要接受推送提示的地方。

不过值得注意的是一般情况下如果推送量较为大的话公司会选择一些比较大的云服务来做,比如笔者的公司就是使用的融云服务来做的,等笔者有空的话会专门开一次坑讲一讲融云服务的教程

 

最新文章

  1. Intent
  2. 聊一聊log4j2配置文件log4j2.xml
  3. Android入门(十三)内容提供器
  4. 几个容易被忽略的mysql知识
  5. spring记录
  6. 解决 internet connection sharing 启动不了
  7. ASP.NET MVC3更新出错:ObjectStateManager中已存在具有同一键的对象
  8. iOS-JS交互 (WebViewJavascriptBridge)
  9. Qt使用Cookies对网站操作之Get和POST
  10. 属性声明(property declarations), 自定义属性,自动生成 get 和 set 方法,getter 和 setter
  11. MD5加密详解
  12. iOS开发系列-UI基础-KVC
  13. 在""中添加"
  14. [Inside HotSpot] C1编译器优化:全局值编号(GVN)
  15. C#实现以太仿DApp合约编译、部署
  16. PyTorch 使用心得
  17. 8.2 C++标准输出流对象
  18. Haskell语言学习笔记(86)字符串格式化与插值
  19. python使用websocket简单组建聊天室
  20. ExtJS 4.2 教程-05:客户端代理(proxy)

热门文章

  1. Google APAC----Africa 2010, Qualification Round(Problem A. Store Credit)----Perl 解法
  2. 简单使用git上传代码
  3. .NET 跨平台服务端资料
  4. vsftpd for Anonymous Downloads on Ubuntu 16.04
  5. MooseFS安装部署
  6. day04之VUE痛悟
  7. C#调用C++函数
  8. INSERT CLAUSE
  9. composer 应用【Modern PHP】
  10. 分享PHP小马一枚,完美绕过安全狗检测。