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

 更新时间:2013年04月26日 10:41:43   作者:  
本篇文章介绍了,关于jQuery新的事件绑定机制on()的使用技巧。需要的朋友参考下

今天浏览jQuery的deprecated列表,发现live()和die()在里面了,赶紧看了一下,发现从jQuery1.7开始,jQuery引入了全新的事件绑定机制,on()和off()两个函数统一处理事件绑定。因为在此之前有bind(), live(), delegate()等方法来处理事件绑定,jQuery从性能优化以及方式统一方面考虑决定推出新的函数来统一事件绑定方法并且替换掉以前的方法。

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

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

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

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

fn:该事件被触发时执行的函数。 false 值也可以做一个函数的简写,返回false。

替换bind()

当第二个参数'selector'为null时,on()和bind()其实在用法上基本上没有任何区别了,所以我们可以认为on()只是比bind()多了一个可选的'selector'参数,所以on()可以非常方便的换掉bind()

替换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()吧,这个没有变化。

相关文章

  • jQuery function的正确书写方法

    jQuery function的正确书写方法

    jQuery function想必大家都不会陌生,web前端开发人员经常会接触到,下面为大家介绍下它的正确书写方法,感兴趣的朋友可以参考下
    2013-08-08
  • jQuery on方法传递参数示例

    jQuery on方法传递参数示例

    这篇文章主要介绍了jQuery on方法传递参数示例,本文给出了一个传递3个参数的例子,需要的朋友可以参考下
    2014-12-12
  • jquery 实现checkbox全选,反选,全不选等功能代码(奇数)

    jquery 实现checkbox全选,反选,全不选等功能代码(奇数)

    jquery 实现全选,反选,全不选等功能,下面直接以例子进行说明,需要的朋友可以参考下
    2012-10-10
  • 基于jQuery实现的无刷新表格分页实例

    基于jQuery实现的无刷新表格分页实例

    这篇文章主要介绍了基于jQuery实现的无刷新表格分页方法,结合完整实例形式较为详细的分析了jQuery实现无刷新表格分页的具体步骤与相关实现代码,需要的朋友可以参考下
    2016-02-02
  • jquery实现二级导航下拉菜单效果实例

    jquery实现二级导航下拉菜单效果实例

    这篇文章主要介绍了jquery二级导航下拉菜单,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • jQuery源码分析之Event事件分析

    jQuery源码分析之Event事件分析

    对于javascript事件扩展,所有的lib都差不多。和jquery和prototype,yui和Ext,其要解决的首要问题是兼容性,所有 lib都会对event进行包裹,统一其属性解决其兼容性。
    2010-06-06
  • Jquery跨浏览器文本复制插件Zero Clipboard的使用方法

    Jquery跨浏览器文本复制插件Zero Clipboard的使用方法

    这篇文章主要介绍了Jquery跨浏览器文本复制插件Zero Clipboard的使用方法,需要的朋友可以参考下
    2016-02-02
  • jQuery aminate方法定位到页面具体位置

    jQuery aminate方法定位到页面具体位置

    jQuery如何定位到页面具体位置,我们可以通过jQuery的aminate动画方法定位,下面有个不粗的示例,感兴趣的朋友可以参考下
    2013-12-12
  • 基于jQuery的ajax方法封装

    基于jQuery的ajax方法封装

    AJAX 是一种用于创建快速动态网页的技术。这篇文章主要介绍了基于jQuery的ajax方法封装的相关资料,需要的朋友可以参考下
    2016-07-07
  • jQuery实现聊天对话框

    jQuery实现聊天对话框

    这篇文章主要为大家详细介绍了jQuery实现聊天对话框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-02-02

最新评论