WebSocket插件
;!(function(window){
"use strict";
let Event = {
wsMesEvent:function(message){
console.log(message)
}
}
,dftOpt = {
protocol:(window.location.protocol == 'http:') ? 'ws://' : 'wss://'
,host:window.location.host
,port:'80'
,path:''
,isReConect:false
,wsMesEvent:Event.wsMesEvent
}
,Util = {
arrayLike(arrayLike){ Array.from(arrayLike)}
,isArray(arr){Array.isArray(arr)}
,forEach(array,iterate){
let index = -1
,length = array.length;
if(typeof iterate != 'function'){return array;}
while (++index < length) {
iterate.call(array,array[index], index);
}
}
,isPlainObject(obj){
let flag = false;
if(!obj || typeof obj != 'object'){return flag;}
if(obj.constructor.prototype.hasOwnProperty("isPrototypeOf")){
flag = true;
}
return flag;
}
,extend(...args){
if(args.length <= 0){return};
let target = args[0];
if(args.length == 1){return args[0]};
this.forEach(args,(arg,i) => {
if(i!=0){
var keys = Object.keys(arg);
this.forEach(keys,(key,i) => {
var val = arg[key];
if(this.isPlainObject(val) || this.isArray(val)){
var newTarget = this.isArray(val)?[]:{};
target[key] = this.extend(newTarget,val);
}else{
target[key] = val;
}
});
}
});
return target;
}
}
,Ws = function (opt) {
//如果浏览器不支持websocket,直接退出
if(!this.isSupportWs()){
alert("对不起,您的浏览器在不支持WebSocket,请先升级您的浏览器!!");
return;
}
let config = this.config = Util.extend({},dftOpt,opt);
//接口地址url
this.url = config.protocol + config.host +':'+config.port + config.path;
//心跳状态 为false时不能执行操作 等待重连
this.isHeartBeat = false ;
//重连状态 避免不间断的重连操作
this.isReconnect = config.isReConect;
//发送的消息
this.curSendMes = null;
//响应的信息
this.message = null;
//创建webSocket
this.ws;
//初始化websocket
this.initWs = function(){
//创建WebSocket
let ws = this.ws = new WebSocket(this.url);
//Ws连接函数:服务器连接成功
ws.onopen = (e) => {
console.log(`与${this.config.host}:${this.config.port}${this.config.path}连接已建立...`)
this.isHeartBeat = true;
//发布事件
this.send();
};
//Ws消息接收函数:服务器向前端推送消息时触发
ws.onmessage = (e) => {
//处理各种推送消
this.message = e.data;
config.wsMesEvent.apply(this,[e.data]);
}
//Ws异常事件:Ws报错后触发
ws.onerror = (e) => {
this.isHeartBeat = false;
this.reConnect();
}
//Ws关闭事件:Ws连接关闭后触发
ws.onclose = (e) => {
console.log('连接已关闭...');
this.isHeartBeat = false;
ws = null;
this.reConnect();
};
};
this.initWs();
};
//判断是否支持WebSocket
Ws.prototype.isSupportWs = function(){
return (window.WebSocket || window.MozWebSocket)?true:false;
}
//重新连接
Ws.prototype.reConnect = function () {
//不需要重新连接,直接返回
if(!this.isReconnect) return;
this.isReconnect = true;
//没连接上 会一直重连,设置延迟避免请求过多
setTimeout(()=>{
this.initWs()
this.isReconnect = false;
}, 5000);
}
//发送消息
Ws.prototype.send = function(content){
this.curSendMes = content || this.curSendMes;
if(this.isHeartBeat){
this.ws.send(this.curSendMes);
}
}
window.Ws = Ws;
})(window);
/***
* 使用方式:
* //建立连接
* var ws1 = new Ws({
* host:'123.207.167.163'
* ,port:9010
* ,path:'/ajaxchattest'
* ,wsMesEvent:function(message){
* console.log(message)
* }
* });
* //发送请求
* ws1.send("111");
*
* //建立连接
* var ws2 = new Ws({
* host:'123.207.167.163'
* ,port:9010
* ,path:'/ajaxchattest'
* ,wsMesEvent:function(message){
* console.log(message)
* }
* });
* //发送请求
* ws2.send("222");
* */
WebSocket插件的更多相关文章
- Jmeter websocket插件安装与使用
Jmeter websocket插件安装与使用 Apache JMeter是Apache组织开发的基于Java的压力测试工具.用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试 ...
- Jmeter使用Websocket插件测试SingalR,外加还有阿里云PTS的Jmeter原生测试爬坑日志。
题外话:距离我的上一篇博客已经过去7年多了,我实在是个不务正业的程序员,遇到测试方面的东西总想分享一下,因为可用的资料实在太少了(包括国外的资料). 本人不喜欢授人以鱼,所以不会直接给出问题和解决方案 ...
- Jquery封装: WebSocket插件
1 $(function() { var websocket = null; //浏览器是否支持websocket if ("WebSocket" in window) { try ...
- sockjs+stomp的websocket插件
/** * 依赖文件sockjs.js.stomp.js * */ ;!(function (window) { 'use strict' let WS = function () { //保存所有的 ...
- WebSocket学习笔记——无痛入门
WebSocket学习笔记——无痛入门 标签: websocket 2014-04-09 22:05 4987人阅读 评论(1) 收藏 举报 分类: 物联网学习笔记(37) 版权声明:本文为博主原 ...
- [Openfire]使用WebSocket建立Openfire的客户端
近日工作闲暇之余,对IM系统产生了兴趣,转而研究了IM的内容.找了半天,知道比较流行的是Openfire的系统,Openfire有许多平台实现,由于我是做Web的,所以当然是希望寻找Web的实现.Op ...
- vue各种插件汇总
https://blog.csdn.net/wh8_2011/article/details/80497620(copy) Vue是什么? Vue.js(读音 /vjuː/, 类似于 view) 是一 ...
- VUE插件大总结
UI组件 element - 饿了么出品的Vue2的web UI工具套件 Vux - 基于Vue和WeUI的组件库 mint-ui - Vue 2的移动UI元素 iview - 基于 Vuejs 的开 ...
- vue插件大全汇总
Vue是一个构建数据驱动的 web 界面的渐进式框架.Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件特别整理了常用的vue插件,来了个大汇总,方便查找使用,便于工作 ...
随机推荐
- vue内使用echarts
18年下班年用的vue + echarts,现在才想起来总结,着实不敬业 线上的项目叫股往(http://rich.xchol.com/#/) 好了,进入正题: 首先,需要新建一个vue的项目,在vu ...
- jmeter基本组件介绍
常用术语统一:元件-jmeter工具菜单的一个子菜单(功能) 组件-一组元件的集合.如http请求与取样器的的关系 jmeter测试计划要素: (1)脚本中测试计划只能有一个: (2)测试计划中至 ...
- 19.Tomcat集群架构
1.Nginx+Tomcat集群架构介绍 2.Nginx+Tomcat集群架构实战 [root@lb01 conf.d]# cat proxy_zrlog.cheng.com.conf upstrea ...
- OpenGL glMatrixMode() 函数解释与例子
概述 glMatrixMode() 用以指定当前要操作的矩阵,可选值有 GL_MODELVIEW(模型视图,默认值),GL_PROJECTION(投影),GL_TEXTURE(纹理),GL_COLOR ...
- RabbitMQ通过DLX实现消息延迟接收
1. 创建队列WorkQueue,并把WorkQueue跟exchangeWork绑定:2. 创建队列DLXQueue,并把DLXQueue跟exchangeDLX绑定:a. 设置DLXQueue队列 ...
- 推荐一款现代化的脚手架项目《hope-boot》
简介: > 一款现代化的脚手架项目.企业开发?接外包?赚外快?还是学习?这都能满足你,居家必备,值得拥有
- human_pose_estimation_demo的再进一步研究
这次研究的主要是速度问题,后来还获得了其它方面的收获. 1.原始的抽帧 对于这样一个问题,想提高速度,能够想到的最简单.最直接的方法就是“抽帧”.比如添加一个计数器 这里,只有当Sumof ...
- zepto源码分析·event模块
准备知识 事件的本质就是发布/订阅模式,dom事件也不例外:先简单说明下发布/订阅模式,dom事件api和兼容性 发布/订阅模式 所谓发布/订阅模式,用一个形象的比喻就是买房的人订阅楼房消息,售楼处发 ...
- NetworkManager网络通讯_networkReader/Writer(六)
unet客户端和服务端进行消息发送时可以采用上一节中方法,也可以直接用networkReader/Writer类进行发送 (一)服务端/客户端注册消息 ; m_Server.RegisterHandl ...
- LogBack.xml文件配置
Logback-spring.xml配置文件 1.日志级别:日志级别从低到高分为TRACE < DEBUG < INFO < WARN < ERROR < FATAL, ...