JS 控件事件小结


Posted in Javascript onOctober 31, 2012

概述:

事件对于控件来说至关重要,控件的消息通信机制使用事件的成本最低,但是对于JS控件来说有一些麻烦需要解决,JS类本身不支持事件,DOM模型支持的事件仅适应于浏览器的DOM节点。所以创建一套事件是我们写控件之前要做的。

事件机制

对于事件的机制我不想多说,各种语言中对事件的描述都很具体,都是观察者模式的一种实现,我们可以从中抽取出事件必须的接口(由于控件库是基于jQuery 所以接口跟jquery保持一致):

1.on: 绑定事件

2.off: 删除事件

3.fire: 触发事件

4.addTarget : 添加冒泡的对象

5.publish: 允许事件冒泡

jQuery 中的事件

jQuery 中的事件功能缺失很丰富,但是必须是jQuery对象才支持,我们自己定义的控件类无法直接使用jQuery的事件,事件的上下文也有问题,所以我们需要自己封装控件的事件。

jQuery 中的 Callbacks 是 1.7中添加的用于回调的机制,使用起来很方便,但是问题也是指定上下文需要在触发时指定,我们可以将其封装到我们自己的事件类中。

绑定事件:

函数原型: function on(eventType,callback) 参数:
1.eventType : 事件类型
2.callback : 回调函数
3.scope : 回调函数的上下文,这个变量在真正的控件绑定过程中使用的非常少,而且都有替代方案,所以为了简单起见,scope变量在此函数和下面的所有函数中就引入了。

上面回调函数的上下文是绑定事件的控件本身

删除绑定:
函数原型 : function off(eventType,callback) 参数同上:

1.eventType : 事件类型
2.callback : 回调函数,此变量省略时,删除这个事件类型的所有绑定函数。
在真正的控件开发和使用过程中,删除事件比绑定事件要麻烦的多,删除事件时,你需要有绑定事件时函数的引用,如果需要频繁删除添加同一个事件时请考虑使用delegate

触发事件
函数原型: fire(eventType) :

1. eventType : 事件类型,绑定到对象上的此类型的函数执行。

这里有2点需要注意:

1.触发事件的方式,我们这里使用 ‘stopOnFalse'的方式,也就是绑定在同一个事件类型下的函数顺序执行,如果有一个返回值为false,那么下面的函数终止执行。其他触发事件的方式参考 jquery 的 Callbacks 。

2.事件的是否冒泡执行,也就是说,如果一个控件有多个子控件,那么子控件触发点击事件时可以冒泡到父类控件,我们只需要监听父类的冒泡事件即可

事件冒泡

函数原型: function(eventType,bubble) :

1.eventType : 事件类型
2.bubble : 是否冒泡

此函数与 function addTarget(control) 相匹配使用。

addTarget 添加事件冒泡到的对象上,控件实现中,默认指定控件的父控件作为其冒泡的对象。

上面触发事件中讲到的,允许控件事件冒泡有很多好处:

1. 事件绑定后,子控件的添加删除不受影响

2. 事件使用更加方便,不需要去了解控件的内部

跟事件冒泡对应的是委托(delegate和 undelegate),委托依赖于事件冒泡,DOM的事件机制和jQuery都支持委托,这是因为浏览器本身对DOM 事件冒泡的支持,而我们在控件上实现的事件冒泡机制足够我们实现委托的效果,所以委托的接口我们就不实现了。

事件代码实现

具体的代码实现和一些帮助方法我写到下面的代码中,不便于在文章中展开,感兴趣的可以看一下,后面的控件库都是基于这些帮助方法和事件对象的。文件里面的其他帮助方法,在其他章节讲解。

Javascript 相关文章推荐
jQuery 入门讲解1
Apr 15 Javascript
js post方式传递提交的实现代码
May 31 Javascript
javascript 弹出层组件(升级版)
May 12 Javascript
JQuery 操作/获取table具体代码
Jun 13 Javascript
JS cookie中文乱码解决方法
Jan 28 Javascript
jQuery表格行上移下移和置顶的实现方法
Oct 08 Javascript
Javascript的表单验证-揭开正则表达式的面纱
Mar 18 Javascript
ES5学习教程之Array对象
Apr 01 Javascript
angularjs下拉框空白的解决办法
Jun 20 Javascript
详解微信小程序实现仿微信聊天界面(各种细节处理)
Feb 17 Javascript
js实现删除li标签一行内容
Apr 16 Javascript
echarts实现获取datazoom的起始值(包括x轴和y轴)
Jul 20 Javascript
jQuery事件 delegate()使用方法介绍
Oct 30 #Javascript
fancybox modal的完美解决(右上的X)
Oct 30 #Javascript
基于jquery自己写tab滑动门(通用版)
Oct 30 #Javascript
基于jquery的滚动条滚动固定div(附演示下载)
Oct 29 #Javascript
使用jquery动态加载javascript以减少服务器压力
Oct 29 #Javascript
不使用XMLHttpRequest实现异步加载 Iframe和script
Oct 29 #Javascript
js制作的鼠标悬浮时产生的下拉框效果
Oct 27 #Javascript
You might like
PHP排序算法之冒泡排序(Bubble Sort)实现方法详解
2018/04/20 PHP
自己的js工具 Cookie 封装
2009/08/21 Javascript
JavaScript学习笔记(十七)js 优化
2010/02/04 Javascript
defer属性导致引用JQuery的页面报“浏览器无法打开网站xxx,操作被中止”错误的解决方法
2010/04/27 Javascript
基于jquery的气泡提示效果
2010/05/31 Javascript
使用cluster 将自己的Node服务器扩展为多线程服务器
2014/11/10 Javascript
js编写当天简单日历效果【实现代码】
2016/05/03 Javascript
浅析Bootstrap验证控件的使用
2016/06/23 Javascript
Bootstrap导航条的使用和理解3
2016/12/14 Javascript
BootStrap 下拉菜单点击之后不会出现下拉菜单(下拉菜单不弹出)的解决方案
2016/12/14 Javascript
jQuery文字轮播特效
2017/02/12 Javascript
vue-cli项目中怎么使用mock数据
2017/09/27 Javascript
AngularJS实现controller控制器间共享数据的方法示例
2017/10/30 Javascript
React从react-router路由上做登陆验证控制的方法
2018/05/10 Javascript
Vue中util的工具函数实例详解
2019/07/08 Javascript
新手入门js闭包学习过程解析
2019/10/08 Javascript
Javascript查看大图功能代码实现
2020/05/07 Javascript
部署vue+Springboot前后端分离项目的步骤实现
2020/05/31 Javascript
python封装对象实现时间效果
2020/04/23 Python
Python操作Oracle数据库的简单方法和封装类实例
2018/05/07 Python
Python格式化日期时间操作示例
2018/06/28 Python
对python for 文件指定行读写操作详解
2018/12/29 Python
python GUI库图形界面开发之PyQt5多行文本框控件QTextEdit详细使用方法实例
2020/02/28 Python
Python PyQt5运行程序把输出信息展示到GUI图形界面上
2020/04/27 Python
Python plt 利用subplot 实现在一张画布同时画多张图
2021/02/26 Python
FitFlop美国官网:英国符合人体工学的鞋类品牌
2018/10/05 全球购物
建龙钢铁面试总结
2014/04/15 面试题
大二学生职业生涯规划书
2014/02/05 职场文书
基层党组织公开承诺书
2014/03/28 职场文书
幼儿教师寄语集锦
2014/04/03 职场文书
《春笋》教学反思
2014/04/15 职场文书
大学生评语大全
2014/04/18 职场文书
《祁黄羊》教学反思
2014/04/22 职场文书
如何写辞职信
2015/05/13 职场文书
修改MySQL的数据库引擎为INNODB的方法
2021/05/26 MySQL
vue项目支付功能代码详解
2022/02/18 Vue.js