JavaScript,封装库--事件绑定

在函数库添加两个函数

添加事件绑定函数

删除事件绑定函数

添加事件绑定函数

/** addEvent()函数库函数,跨浏览器添加事件绑定,注意:传入事件名称时不要on
* 接收3个参数
* 参数1要绑定事件的元素对象,
* 参数2事件名称,也就是什么事件,注意:传入事件名称时不要on
* 参数3接收的事件执行函数
* 注意:一个元素对象,执行了多个相同的事件函数时只执行一次,其他的会被忽略,注意是相同的事件函数
* 说明:
* 事件函数里的this,代表绑定事件元素对象本身
* 事件函数里有一个可选参数e,e接收的元素event对象,传入addEvent()后跨浏览器获取到元素event对象,将元素event对象赋值给e
* 所以事件函数里的e,代表元素event对象,前提是首先要在事件函数传参e后,再在事件函数里调用e,得到元素event对象
* e.preventDefault()方法,在事件函数里写e.preventDefault()方法,兼容浏览器阻止事件元素对象默认行为,前提在事件函数要传参e
* e.stopPropagation()方法,在事件函数里写e.stopPropagation()方法,阻止元素对象的父级元素事件冒泡行为,前提在事件函数要传参e
**/
function addEvent(obj, type, fn) {
if (typeof obj.addEventListener != 'undefined') {
obj.addEventListener(type, fn, false);
} else {
//创建一个存放事件的哈希表(散列表)
if (!obj.events) obj.events = {};
//第一次执行时执行
if (!obj.events[type]) {
//创建一个存放事件处理函数的数组
obj.events[type] = [];
//把第一次的事件处理函数先储存到第一个位置上
if (obj['on' + type]) obj.events[type][0] = fn;
} else {
//同一个注册函数进行屏蔽,不添加到计数器中
if (addEvent.equal(obj.events[type], fn)) return false;
}
//从第二次开始我们用事件计数器来存储
obj.events[type][addEvent.ID++] = fn;
//执行事件处理函数
obj['on' + type] = addEvent.exec;
}
}
/*-------------------------------------------------------------------------------------*/
//为每个事件分配一个计数器
//JS一切皆为对象,所以addEvent.ID语法正确,实际上是个全局变量
addEvent.ID = 1;
//执行事件处理函数
addEvent.exec = function (event) {
var e = event || addEvent.fixEvent(window.event);
var es = this.events[e.type];
for (var i in es) {
es[i].call(this, e);
}
};
//同一个注册函数进行屏蔽
addEvent.equal = function (es, fn) {
for (var i in es) {
if (es[i] == fn) return true;
}
return false;
};
//把IE常用的Event对象配对到W3C中去
addEvent.fixEvent = function (event) {
event.preventDefault = addEvent.fixEvent.preventDefault;
event.stopPropagation = addEvent.fixEvent.stopPropagation;
return event;
};
//IE阻止默认行为
addEvent.fixEvent.preventDefault = function () {
this.returnValue = false;
};
//IE取消冒泡
addEvent.fixEvent.stopPropagation = function () {
this.cancelBubble = true;
};
/*---------------------------------------------------------------------------------------*/

删除事件绑定函数

/** removeEvent()函数库函数,跨浏览器删除事件绑定,注意:传入事件名称时不要on
* 接收3个参数
* 参数1接收事件绑定时的元素对象
* 参数2接收事件绑定时的事件名称,也就是什么事件,注意:传入事件名称时不要on
* 参数3接收事件绑定时的执行函数
**/
function removeEvent(obj, type, fn) {
if (typeof obj.removeEventListener != 'undefined') {
obj.removeEventListener(type, fn, false);
} else {
for (var i in obj.events[type]) {
if (obj.events[type][i] == fn) {
delete obj.events[type][i];
}
}
}
}

最新文章

  1. pcl曲面重建模块-poisson重建算法示例
  2. ajax无刷新异步传输
  3. ACM: Hotel 解题报告 - 线段树-区间合并
  4. Java FX中TreeView节点选中和双击事件监听
  5. Spring学习(二)——Spring中的AOP的初步理解[转]
  6. hdu5442(2015长春赛区网络赛1006)后缀数组+KMP /最小表示法?
  7. ps调色技能
  8. 几种交换两个数函数(swap函数)的写法和解析
  9. K. Perpetuum Mobile
  10. 【Alpha】Daily Scrum Meeting——Day6
  11. 集合框架之Map接口
  12. [Swift]LeetCode331. 验证二叉树的前序序列化 | Verify Preorder Serialization of a Binary Tree
  13. BeautifulSoup学习 之结构
  14. 原生js的ajax请求
  15. Android笔记:OptionsMenu
  16. Mac系统登录不进系统解决办法
  17. [转载]windows下PHP + Nginx curl访问本地地址超时卡死问题的解决方案
  18. jQuery速看
  19. Java HashMap 遍历方式探讨
  20. java查找字符串里与指定字符串相同的个数

热门文章

  1. activemq集群搭建Demo
  2. Git学习笔记一--创建版本库、添加文件、提交文件等
  3. Style对象之一
  4. Java学习笔记3、变量、数据类型
  5. WebBrowser.ExecWB
  6. sql getdate()生成单据号
  7. php安全处理
  8. mysql创建账号对应的数据库方法
  9. Application Request Route实现IIS Server Farms集群负载详解(转)
  10. 查询清除SQL Server数据库备份还原历史记录