Web页面多对象多文档事件冲突的解决方案
这段时间写了很多基于js和jquery的前端控件,每一个的功能都很复杂,事件也很多。
因为都是单独封装的,单独使用没有问题,但把他们放到一个页面使用,就经常发生事件冲突的问题。
这几天一直在考虑用一个什么比较好的方法解决,今天把其中一个解决方案实验了一下,感觉很不错,现在发出来,大家一起探讨下。
window.UE_EVENT = window.UE_EVENT || {
Key: 1,
ClipBoard: null,
CurrElement: null,
CurrKey: 0,
Events: { 'mousemove': [], 'mousedown': [], 'keypress': [], 'dblclick': [], 'mouseup': [], 'keydown': [], 'keyup': [], 'click': [], 'resize': [], 'copy': [], 'paste': [] },
Delete: function (event, key) {
if (!event || !key) return false;
var e = event.toLowerCase(),l = this.Events[e];
for (var i in l) {
if (l[i].KEY == key) {
l.splice(i, 1);
break;
}
}
},
Add: function (dom, event, callback) {
if (!dom || !event || !callback) return false;
UE_EVENT.IsRun || UE_EVENT.Run();
var key = UE_EVENT.SetEventKey(dom), isExists = false, e = event.toLowerCase(), l = this.Events[e];
for (var i in l) {
if (l[i].KEY == key) {
l[i].FUN = callback;
isExists = true;
}
}
if (!isExists) {
l.push({ 'KEY': key, 'EVENT': e, 'DOM': dom[0] || dom, 'FUN': callback });
}
},
Excute: function (event, e) {
var l = this.Events[event];
if (event == 'resize') {
for (var i in l) {
var t = l[i], d = t.DOM;
if (t.width != $(d).width() || t.height != $(d).height()) {
t.width = $(d).width();
t.height = $(d).height();
l[i].FUN(t.width, t.height, null, d);
}
}
} else {
e = e || window.event;
var t = e.srcElement || e.target,
k = parseInt($(t).attr('eventkey'), 10);
for (var i in l) {
if (l[i].KEY == k || l[i].KEY == this.CurrKey) {
l[i].FUN(e, t, l[i].KEY, l[i].DOM);
}
}
}
},
Download: function (url, json) {
var form = $('<form style="display:none" target="ue_download_iframe" method="post" action="' + url + '"><iframe id="ue_download_iframe" name="ue_download_iframe" onload=""></iframe><input name="JsonData" value="' + JSON.stringify(json).replace(/"/g, "'") + '" /></form>').appendTo('body');
var iframe = document.getElementById('ue_download_iframe');
if (document.readyState) {
iframe.onreadystatechange = function () {
if (this.readyState && this.readyState == 'complete') {
form.remove();
}
}
} else {
iframe.onload = function () {
form.remove();
}
}
form.submit();
},
SetEventKey: function (obj) {
if (!obj) return;
var dom = obj[0] || obj,
isDOM = (typeof HTMLElement === 'object') ? (dom instanceof HTMLElement) : dom && typeof dom === 'object' && dom.nodeType === 1,
key = isDOM ? parseInt($(dom).attr('eventkey'), 10) : dom.eventKey;
key = key || UE_EVENT.Key++;
if (isDOM) {
$(dom).attr('eventkey', key)
} else {
dom.eventKey = key;
}
return key;
},
Run: function (obj) {
if (!this.IsRun) {
$(document).on('mousemove', function (e) {
UE_EVENT.Excute('mousemove', e);
}).on('mousedown', function (e) {
UE_EVENT.Excute('mousedown', e);
}).on('keypress', function (e) {
UE_EVENT.Excute('keypress', e);
}).on('dblclick', function (e) {
UE_EVENT.Excute('dblclick', e);
}).on('mouseup', function (e) {
UE_EVENT.Excute('mouseup', e);
}).on('keydown', function (e) {
UE_EVENT.Excute('keydown', e);
}).on('keyup', function (e) {
UE_EVENT.Excute('keyup', e);
}).on('click', function (e) {
UE_EVENT.CurrKey = 0;
UE_EVENT.Excute('click', e);
});
setInterval(function () { UE_EVENT.Excute('resize', null); }, 200);
//$(window).on('resize', function (e) {
// UE_EVENT.Excute('resize', e);
//});
$('body').on({
copy: function (e) {
var d = window.clipboardData || e.originalEvent.clipboardData;
var txt = "";
UE_EVENT.Excute('copy', txt);
d.setData('Text', txt);
return false;
},
paste: function (e) {
var d = window.clipboardData || e.originalEvent.clipboardData;
UE_EVENT.Excute('paste', d.getData('Text'));
}
});
}
UE_EVENT.IsRun = true;
return true;
}
};
$.fn.SetEvent = function (event, callback) {
return UE_EVENT.Add(this, event, callback);
};
$.fn.ActiveEvent = function () {
UE_EVENT.CurrKey = UE_EVENT.SetEventKey(this);
};
这个方案的思路就是用单例模式,建立一个事件方法列表,就像系统的注册表一样(事实上灵感也是来自注册表),
然后所有的插件控件的文档事件,都向这个列表集合里注册,这样需要用的时候,就能统一调度,互不冲突。
今天做了一点调整,就是添加了dom对象的保存,同时注册的事件改为保存事件名称,这样可能比较灵活
一改:添加了resize事件
二改:这次改为每添加一个事件,都指定一个key值
三改:修改resize事件为实时监控标签size变化,取消绑定body的resize事件
添加copy和poaste事件
Web页面多对象多文档事件冲突的解决方案的更多相关文章
- 前端(十五)—— JavaScript事件:绑定事件方式、事件的冒泡和默认事件、鼠标事件、键盘事件、表单 事件、文档事件、图片事件、页面事件
JS事件:绑定事件方式.事件的冒泡和默认事件.鼠标事件.键盘事件.表单 事件.文档事件.图片事件.页面事件 一.事件的两种绑定方式 1.on事件绑定方式 document.onclick = func ...
- WEB前端开发规范文档(转)
http://codeguide.bootcss.com/ 编写灵活.稳定.高质量的 HTML 和 CSS 代码的规范上面的文档 再结合下面的规范: 无论是从技术角度还是开发视角,对于web前端开发 ...
- 网站开发进阶(三十八)Web前端开发规范文档你需要知道的事
Web前端开发规范文档你需要知道的事 规范目的 为提高团队协作效率, 便于后台人员添加功能及前端后期优化维护, 输出高质量的文档, 特制订此文档. 本规范文档一经确认, 前端开发人员必须按本文档规范进 ...
- Web前端开发规范文档你需要知道的事
Web前端开发规范文档你需要知道的事 规范目的 为提高团队协作效率, 便于后台人员添加功能及前端后期优化维护, 输出高质量的文档, 特制订此文档. 本规范文档一经确认, 前端开发人员必须按本文档规范进 ...
- WEB前端开发规范文档[转]
为新项目写的一份规范文档, 分享给大家. 我想前端开发过程中, 无论是团队开发, 还是单兵做站, 有一份开发文档做规范, 对开发工作都是很有益的. 本文档由本人编写, 部分意见来源于网络, 以此感谢, ...
- ASP.NET Core 中文文档 第二章 指南 (09) 使用 Swagger 生成 ASP.NET Web API 在线帮助测试文档
原文:ASP.NET Web API Help Pages using Swagger 作者:Shayne Boyer 翻译:谢炀(kiler) 翻译:许登洋(Seay) 对于开发人员来说,构建一个消 ...
- WEB文档在线预览解决方案
web页面无法支持预览office文档,但是却可以预览PDF.flash文档,所以大多数解决方案都是在服务端将office文档转换为pdf,然后再通过js的pdf预览插件(谷歌浏览器等已经原生支持嵌入 ...
- 关于ASP.NET Web Api的HelpPage文档注释问题
关于ASP.NET Web Api的HelpPage文档注释问题 以前我用微软的HelpPage来自动生成的webAPI帮助文档.在使用了一段时间后发现只能显示Controller上面写的注释文档内容 ...
- web通信之跨文档通信 postMessage
index.html <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type&qu ...
随机推荐
- 【Unity3D技巧】在Unity中使用事件/委托机制(event/delegate)进行GameObject之间的通信 (二) : 引入中间层NotificationCenter
作者:王选易,出处:http://www.cnblogs.com/neverdie/ 欢迎转载,也请保留这段声明.如果你喜欢这篇文章,请点[推荐].谢谢! 一对多的观察者模式机制有什么缺点? 想要查看 ...
- 苹果Mac OS X显示隐藏文件的方法
苹果Mac OS X显示隐藏文件的方法有很多种,这里介绍一种最简单的, 方法/步骤 打开“终端”,根据自己的版本选择命令 早期的OS X(10.6~10.8)系统可以使用如下两条命令来开始 ...
- [linux] Nginx编译安装错误error: the HTTP rewrite module requires the PCRE library
nginx编译错误: 执行如下命令安装缺少的文件即可
- 【freemaker】之获取xml的值
测试代码 @Test public void test09() throws Exception{ root.put("doc", NodeModel.parse(new Inpu ...
- 使用C#访问SQLLite
1.SQLLite如何集成在C#中 2.相关C#与SQLLite资源,及说明 3.简单示例
- 实现远程连接ACCESS数据库的方法
使用了TCP/IP,ADO及(需要安装Microsoft 4.0.).分服务器和客户端两部分,可以多用户同时连接.远程连接Access有很多方法,我以前已经比较详细的回答过(见下面所列的5种方法),我 ...
- ORA-00245: control file backup failed; target is likely on a local file system
ORACLE11G RAC alert报错如下:Errors in file /u01/app/oracle/diag/rdbms/dljyzs/dljyzs1/trace/dljyzs1_ora_8 ...
- 16.检查是否为BST
题目描述 请实现一个函数,检查一棵二叉树是否为二叉查找树. 给定树的根结点指针TreeNode* root,请返回一个bool,代表该树是否为二叉查找树 import java.util.*; /* ...
- 9. Sort List && Insertion Sort List (链表排序总结)
Sort List Sort a linked list in O(n log n) time using constant space complexity. H ...
- 树莓派make 360wifi2报错
输入make命令后报错 make: *** /lib/modules/3.10.25+/build: No such file or directory. Stop. 系统缺少编译模块所需要的内核头文 ...