最近在使用Bootstrap.js,一不小心趴开源码看了一下,尤其是看到tab.js

 var hideEvent = $.Event('hide.bs.tab', {
relatedTarget: $this[0]
}) var showEvent = $.Event('show.bs.tab', {
relatedTarget: $previous[0]
}) $previous.trigger(hideEvent)
$this.trigger(showEvent)

看到这里的时候,顿时一头雾水!然后立马去查了jquery的官方API(http://api.jquery.com/category/events/event-object/),发现原来jQuery.Event 构造器暴露出来,然后通过$.trigger来触发,然后来了个简单的例子

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>$.Event</title>
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.js"></script>
</head>
<body>
<input type="text" id="input-1" />
<script>
$(function(){
var e = jQuery.Event( "keydown",{name:65});
$("#input-1").on("keydown",function(event){
console.log(event.name);//初始化的时候输出 65 ,以后每次keydown都是undefined
})
$( "#input-1" ).trigger( e );
})
</script>
</body>
</html>

  虽然keydown事件中event.name明显是不存在,但是我们通过$.Eevent依然可以输出值65,也就是$.Event通过trigger默认触发事件把属性name绑定到keydown的事件,所以页面加载的时候就输出65,如果你此刻再去对input进行keydown 就显示undefined,根据jQuery官网翻译知道传入的参数的参数可以根据事件的情况而变化,可以是altKey, bubbles, button, cancelable, charCode, clientX, clientY, ctrlKey, currentTarget, data, detail, eventPhase, metaKey, offsetX, offsetY, originalTarget, pageX, pageY, relatedTarget, screenX, screenY, shiftKey, target, view, which

  同样我们来拆解bootstrap中tab.js,我们仿造其原理制作如下函数

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>$.Event</title>
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.js"></script>
</head>
<body>
<input type="text" id="input-1" />
<script>
+function($){
function testEvent(){
var hidden = jQuery.Event( "hide.bs",{
user:"foo",
pass:"bar",
relatedTarget: $("#input-1")[0]
});
$( "#input-1" ).trigger(hidden);
}
$("#input-1").on("click",testEvent);
}(jQuery)
$(function(){
$( "#input-1" ).on("hide.bs",function(event){
alert(event.relatedTarget.tagName)//INPOUT
alert(event.user)//foo
})
})
</script>
</body>
</html>

  事实证明$.Event在自定义函数上面有很强大的 功能存在,通过relatedTarget来指向对应事件的目标DOM元素,如果你看了bootstrap的tab的案例,瞬间就会觉得此功能作用甚大,可是不经间发现了transition.js中对于$.Event的用法让人大吃一惊,在原生js中有handleEvent(IE9+支持)

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>js Handler 事件</title>
</head>
<body>
<button id="btn-1">点击执行click事件</button>
<input type="text" id="input-1" />
<script type="text/javascript">
var Events={
handleEvent: function(event) {
switch (event.type) {
case "click":
this.clickEvent(event);
break;
case "focus":
this.focusEvent(event);
break;
}
},
clickEvent:function(){
alert("执行了click的事件");
},
focusEvent:function(){
alert("执行了focus的事件");
}
}
if(window.addEventListener){
document.getElementById("btn-1").addEventListener("click",Events,false);
document.getElementById("input-1").addEventListener("focus",Events,false);
}
</script>
</body>
</html>

  同样作为大名鼎鼎的jquery,一定也实现了这种方式,果不其然,在transtion.js中可以看到赤裸裸的如何实现这样的方式,同样我们按照transtion.js做了一个精简来执行下面函数

 <!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>handlerEvent</title>
<script src="http://libs.baidu.com/jquery/1.11.1/jquery.js"></script>
<link rel="stylesheet" type="text/css" href="../dist/css/bootstrap.css">
</head> <body>
<button id="btn-1">按钮-1</button>
<script type="text/javascript">
(function($) {
function transitionEnd() {
var el = document.createElement('bootstrap')
var transEndEventNames = {
WebkitTransition: 'webkitTransitionEnd',
MozTransition: 'transitionend',
OTransition: 'oTransitionEnd otransitionend',
transition: 'transitionend'
}
for (var name in transEndEventNames) {
if (el.style[name] !== undefined) {
return {
end: transEndEventNames[name]
}
}
}
return false // explicit for ie8 ( ._.)
}
$.fn.emulateTransitionEnd = function(duration) {
$(this).one('bsTransitionEnd', function() {
alert("执行one('bsTransitionEnd')自定义事件");
})
//在webkit的条件下$.support.transition.end=webkitTransitionEnd
$(this).trigger($.support.transition.end) }
$(function() {
$.support.transition = transitionEnd();
if (!$.support.transition) return;
$.event.special.bsTransitionEnd = {
bindType: $.support.transition.end,
delegateType: $.support.transition.end,
handle: function(e) {
if ($(e.target).is(this)) return e.handleObj.handler.apply(this, arguments)
}
}
})
})(jQuery)
$(function(){
$("#btn-1").emulateTransitionEnd();
}) </script>
</body> </html>

  通过$.event.special.bsTransitionEnd的方式来查找对应执行函数,这个其实就是原声js 的 handleEvent的jQuery实现方式!有时候一个点就可以带出一个面!

随机推荐

  1. Windows Server 2008 R2 IIS重装

    背景描述: 在一个刚睡醒午觉后的下午,忽然收到客户反馈,说昨天开始应用特别卡,各种卡各种不好用,忽然想到上次说要优化服务器IIS配置还一直没弄,然后迷迷糊糊的就开始进行客户现场服务器IIS配置优化,涉 ...

  2. 网页嵌入WMP代码(转)

    网页嵌入WMP代码 播放器代码解释,装了9.0或9.0以上的播放器才能正常使用: OBJECT id="WMP" height="176" width=&quo ...

  3. ckeditor 使用手册

    CKEditor使用手册 在使用CKEditor过程中遇到了一些问题,现把它整理成手册,以便随时翻阅. 在页面<head>中引入ckeditor核心文件ckeditor.js <sc ...

  4. shonc项目中的设计资讯模块 php 字符串操作与正则表达式 strip_tags preg_match

    问题:当description 内容要求description的值选用资讯内容的前50个汉字.资讯内容可能有图片. 此时需要对输出的内容进行处理 php 正则表达式处理,编辑器输出的内容 只取图片: ...

  5. ip聚合(百度之星资格赛1003)

    IP聚合 点击这里 Problem Description 当今世界,网络已经无处不在了,小度熊由于犯了错误,当上了度度公司的网络管理员,他手上有大量的 IP列表,小度熊想知道在某个固定的子网掩码下, ...

  6. 提升Boolean和out相结合的用户体验

    在我们编写代码的过程中经常有这样的需求,比如添加一条数据,我们想要的结果是如果添加成功了就返回true,如果添加失败了就返回false,在返回false的同时携带错误信息,我们通常的做法是定义这样的方 ...

  7. UI产品设计流程中的14个要点

    http://www.sj33.cn/digital/wyll/201404/38318.html 自从我在 Dribbble 上贴了一幅我的产品设计成果,受到了大家伙热烈的反馈,对此我深受鼓励,我决 ...

  8. 把自定义控件集成到Qt Designer中

    要想在Qt Designer中使用自定义控件,必须要使Qt Designer能够知道我们的自定义控件的存在.有两种方法可以把新自定义控件的信息通知给Qt Designer:“升级(promotion) ...

  9. 使用java的wsimport.exe工具生成wsdl的客户端代码

    在jdk的bin目录下有一个wsimport.exe的工具,使用该工具可以根据wsdl地址生成java的客户端代码. 常用命令如下: wsimport  -keep -d d:\ -s d:\src  ...

  10. 胜利大逃亡(续)(状态压缩bfs)

    胜利大逃亡(续) Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total S ...