原创:Javascript Websocket客户端封装
调试中,马马虎虎能用
var LeesWebSocket = function (options) {
this.defaults = {
host: "127.0.0.1",
port: 2015, // callbacks
onOpen: function () { },
onClose: function () { },
onMessage: function (evt) { },
onError: function () { }
}
//调试用---------------------------
mLCQ = new LeesCircleQueue(40); function Trace(s) {
var t = new Date(); mLCQ.Push(t.getHours() + ":" + t.getMinutes() + ":" + t.getSeconds() + " :" + s + "<br>");
showDebuginfo();
}
function showDebuginfo() {
var ss = mLCQ.GetAllItem();
var sb = ''; for (var i = 0; i < ss.length; i++) {
sb += (i + 1) + ":" + ss[i] + "<br>";
}
$('#debug').html(sb);
}
//-------------------------------
//-------------------------------
var opt = $.extend({}, this.defaults, options);
var _this = this;
var wsSocket = null;
this.bIsConnected = false;
var bIsConnecting = false;
this._LWS_Host = "ws://" + opt.host + ":" + opt.port; this.Connect = function () {
if (bIsConnecting)
return;
bIsConnecting = true;
try {
if ("WebSocket" in window) {
wsSocket = new WebSocket(this._LWS_Host);
}
else if ("MozWebSocket" in window) {
wsSocket = new MozWebSocket(this._LWS_Host);
}
wsSocket.onopen = WSonOpen;
wsSocket.onclose = WSonClose;
wsSocket.onmessage = WSonMessage;
wsSocket.onerror = WSonError;
} catch (ex) {
alert(ex);
}
bIsConnecting = false;
}
this.Send = function (s) {
Trace(s);
if (_this.bIsConnected) {
wsSocket.send(s);
return true;
}
return false;
}
this.IsConnected = function () {
return this.bIsConnected;
}
function WSonOpen() {
_this.bIsConnected = true;
opt.onOpen(); }
function WSonMessage(evt) {
opt.onMessage(evt); }
function WSonClose() {
_this.bIsConnected = false;
wsSocket = null;
opt.onClose(); }
function WSonError(evt) {
_this.bIsConnected = false;
wsSocket = null;
opt.onError(); }
}
原创:Javascript Websocket客户端封装的更多相关文章
- [原创]Javascript模拟“类”的综合实现方式以及部分细节【截至ES6】
[原创]Javascript模拟“类”的综合实现方式以及部分细节[截至ES6] 前言 最近几个旧项目里使用的图片编辑插件出现Bug, 经Review 后确定需要在其内外均做些改动,但是头疼的发现部 ...
- ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml) 用javascript在客户端删除某一个cookie键值对 input点击链接另一个页面,各种操作。 C# 往线程里传参数的方法总结 TCP/IP 协议 用C#+Selenium+ChromeDriver 生成我的咕咚跑步路线地图 (转)值得学习百度开源70+项目
ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml) 我们都知道在使用WebApi的时候Controller会自动将Action的返回值自动进行各种序列化处理(序列化为 ...
- netty系列之:使用netty搭建websocket客户端
目录 简介 浏览器客户端 netty对websocket客户端的支持 WebSocketClientHandshaker WebSocketClientCompressionHandler netty ...
- JavaScript获取客户端计算机硬件及系统等信息的方法
JavaScript获取客户端计算机硬件及系统等信息的方法 JavaScript 获取客户端计算机硬件及系统信息 通过WMI来实现获取客户端计算机硬件及系统信息: function getSysInf ...
- javascript通用事件封装
随着最近几年Html5的兴起,越来越多的应用采用html5进行实现,一个优秀的网页应用不但需要美观简洁的UI界面,更需要一个良好的交互.网页应用大部分的交互需要用javascript事件进行实现.虽然 ...
- 我自己的Javascript 库,封装了一些常用函数 Kingwell.js
我自己的Javascript 库,封装了一些常用函数 Kingwell.js 博客分类: Javascript javascript 库javascript库 现在Javascript库海量,流行的 ...
- 用javascript得到客户端IP的新方法
javascript得到客户端IP的新方法 很久以来,我都是经过http://fw.qq.com/ipaddress来得到客户端用户的IP,这个方法简单.快速.实用 . 我们调用它的写法是: < ...
- 【转】SocketRocket:iOS WebSocket客户端开源框架
原文网址:http://blog.csdn.net/zmp1123/article/details/44015507 WebSocket: WebSocket通信协议实现的是基于浏览器的原生socke ...
- JavaScript设计模式之一封装
对于熟悉C#和Java的兄弟们,面向对象的三大思想(封装,继承,多态)肯定是了解的,今天我想讲讲如何在Javascript中利用封装这个特性,开讲! 我们会把现实中的一些事物抽象成一个Class并且把 ...
随机推荐
- 深刻理解Python中的元类(metaclass)
译注:这是一篇在Stack overflow上很热的帖子.提问者自称已经掌握了有关Python OOP编程中的各种概念,但始终觉得元类(metaclass)难以理解.他知道这肯定和自省有关,但仍然觉得 ...
- html5中viewport使用
html5中viewport使用 转载自:http://www.maoegg.com/the-usage-of-viewport-in-html5/ 用html5开发移动应用时往往会遇到手机的分辨率或 ...
- zTree 异步加载
zTree异步加载数据的简单实现,更为详细的Api请参考 zTree官网 http://www.treejs.cn/ <link href="~/Content/ztree/css ...
- 电商ERP常见功能模块
电商ERP是适用企业卖家的专业电子商务ERP,支持淘宝.天猫.京东.1688.当当.苏宁.拍拍.唯品会.亚马逊.独立B2C等多网络销售渠道:也包括 异地多仓..货位管理.智能配货等专业的WMS(仓 ...
- sql基本语法:
1.create database db_name; --创建数据库 2.drop database db_name; --删除数据库 3.show create database db_name\ ...
- JS精确到小数点两位
1.会四色五入 var num =2.446242342; num = num.toFixed(2); // 输出结果为 2.452.正则Number(15.7784514000.toString() ...
- java1.5新特性
一:增强for循环 增强for的格式:for(数据类型 变量名:集合或者 数组){ } 传统的for循环可以对数组进行遍历: for(int x=0;x { Syste ...
- Jquery选择器,操作DOM
刚接触jQuery,她真的是个好东西,操作DOM,修改样式,都很方便,主要获取DOM树的类和子代很方便. 今天用jq做了tab面包屑,不过用的是别人的代码,自己修改的,不错也做出来了,原理也有些明白, ...
- alert
先别着急测试,来猜测一下下面一行代码执行的结果 alert(alert(1234567)); 此刻,我自己还不是不太理解 我的分析是这样: alert() 是window下面的一个方法 alert(1 ...
- Base64 编码
Base64 字母表 Base64 编码将一个 8 位字节序列拆成 6 位的片段,并为每个 6 位的片段分配一个字符,这个字符是 Base64 字母表中的 64 个字符之一. Wert Zeichen ...