关于jQuery新的事件绑定机制on()的使用技巧

从jQuery1.7开始,jQuery引入了全新的事件绑定机制,on()和off()两个函数统一处理事件绑定。由于在此以前有bind(), live(), delegate()等方法来处理事件绑定,jQuery从性能优化以及方式统一方面考虑决定推出新的函数来统一事件绑定方法而且替换掉之前的方法。html

on(events,[selector],[data],fn)jquery

$(elements).on( events [, selector] [, data] , handler );
$(elements).off( [ events ] [, selector] [, handler] );

events:一个或多个用空格分隔的事件类型和可选的命名空间,如"click"或"keydown.myPlugin" 。api

selector:一个选择器字符串用于过滤器的触发事件的选择器元素的后代。若是选择器为null或省略,当它到达选定的元素,事件老是触发。浏览器

data:当一个事件被触发时要传递event.data给事件处理函数。安全

fn:该事件被触发时执行的函数。 false 值也能够作一个函数的简写,返回false。性能优化

替换bind()

当第二个参数'selector'为null时,on()和bind()其实在用法上基本上没有任何区别了,因此咱们能够认为on()只是比bind()多了一个可选的'selector'参数,因此on()能够很是方便的换掉bind()模块化

$( 'a' ).bind( 'click' , myHandler);
$( 'a' ).on( 'click' , myHandler);
$(window).unbind( 'scroll.myPlugin' );
$(window).off( 'scroll.myPlugin' );

替换live()

在1.4以前相信你们很是喜欢使用live(),由于它能够把事件绑定到当前以及之后添加的元素上面,固然在1.4以后delegate()也能够作相似的事情了。live()的原理很简单,它是经过document进行事件委派的,所以咱们也可使用on()经过将事件绑定到document来达到live()同样的效果。函数

live()写法性能

代码以下:

 $('#list li').live('click', '#list li', function() {
    //function code here.
}); 


on()写法
优化

代码以下:

$(document).on('click', '#list li', function() {
    //function code here.
});


这里的关键就是第二个参数'selector'在起做用了。它是一个过滤器的做用,只有被选中元素的后代元素才会触发事件。

替换delegate()
delegate()是1.4引入的,目的是经过祖先元素来代理委派后代元素的事件绑定问题,某种程度上和live()优势类似。只不过live()是经过document元素委派,而delegate则能够是任意的祖先节点。使用on()实现代理的写法和delegate()基本一致。

delegate()的写法

代码以下:

$('#list').delegate('li', 'click', function() {
    //function code here.
});


on()写法

代码以下:

$('#list').on('click', 'li', function() {
    //function code here.
});


貌似第一个和第二个参数的顺序颠倒了一下,别的基本同样。

总结
jQuery推出on()的目的有2个,一是为了统一接口,二是为了提升性能,因此从如今开始用on()替换bind(), live(), delegate吧。尤为是不要再用live()了,由于它已经处于不推荐使用列表了,随时会被干掉。若是只绑定一次事件,那接着用one()吧,这个没有变化。推荐使用on() off().

注:jQuery1.9删除了一些在1.8中已通过时的api

jQuery1.9删除了一些在1.8中已通过时的api,想要把那些不够安全的、缺少效率的、用处不大的,以及带有误导的特性通通去掉。若是你想升级你的jquery版本,但又使用了以下被删除的api的话,能够引入Migrate迁移插件,被删除的api能够在Migrate插件中修复。

.toggle(function, function, … )
toggle()方法可实现点击一个元素来执行指定函数。此方法被删除以减小混乱和提升潜在的模块化程度。

jQuery.browser()
jQuery.browser()经过UA信息来检测浏览器。此方法在1.3版本中已不同意使用,并在1.9版本中被删除,jquery团队更建议经过特性检测来时您的代码兼容浏览器。

.live()
live()方法能够为将来生成的元素添加事件,此方法在1.7版本中已不同意使用,并在1.9版本中被删除,您可使用on()方法来代替。

.die()
die()方法能够移除live()添加的事件,此方法在1.7版本中已不同意使用,并在1.9版本中被删除,您可使用off()方法来代替。

.sub()
sub()方法能够可建立一个新的jQuery副本,不影响原有的jQuery对像,但用例的数量已经不足以证实它存在的价值。

参考:http://www.cnblogs.com/shihao/archive/2012/01/04/2312030.html

   http://www.cnblogs.com/davidwang456/archive/2013/05/12/3073803.html

相关文章
相关标签/搜索