zoukankan      html  css  js  c++  java
  • bind,live,delegate,on绑定事件的方式与区别

    【转】jQuery中bind,live,delegate,on绑定事件的方式与区别

     

    jQuery中提供了四种事件监听方式,分别是bind、live、delegate、on,对应的解除监听的函数分别是unbind、die、undelegate、off。

    已知有4个列表元素:

      列表元素1

      列表元素2

      列表元素3

       列表元素4

      1、bind

    bind(type,[data],function(eventObject))

    bind是使用频率较高的一种,作用就是在选择到的元素上绑定特定事件类型的监听函数,参数的含义如下:

    type:事件类型,如click、change、mouseover等;

    data:传入监听函数的参数,通过event.data取到。可选;

    function:监听函数,可传入event对象,这里的event是jQuery封装的event对象,与原生的event对象有区别,使用时需要注意。

      源码:

    bind: function( types, data, fn ) {

    return this.on( types, null, data, fn );

    }

      可以看到内部是调用了on方法。

      bind的特点就是会把监听器绑定到目标元素上,有一个绑一个,在页面上的元素不会动态添加的时候使用它没什么问题。但如果列表中动态增加一个“列表元素5”,点击它是没有反应的,必须再bind一次才行。

      

      2、live

    live(type, [data], fn)

    live的参数和bind一样,它又有什么蹊跷呢,我们还是先瞄一眼源码:

    live: function( types, data, fn ) {

    jQuery( this.context ).on( types, this.selector, data, fn );

    return this;

    }

    可以看到live方法并没有将监听器绑定到自己(this)身上,而是绑定到了this.context上了。

    live正是利用了事件委托机制来完成事件的监听处理,把节点的处理委托给了document。

    使用事件委托的优点一目了然,新添加的元素不必再绑定一次监听器。

      3、delegate

    将监听事件绑定在就近的父级元素上,源码:

    delegate: function( selector, types, data, fn ) {

    return this.on( types, selector, data, fn );

    }

    这下,我们的选择又多了一些灵活性,不单可以利用事件委托,还可以选择委托的对象。毕竟老麻烦同一个人帮忙很不好嘛。对于如何选择委托对象,还是需要一定的策略的,毕竟父级元素可以有很多。我觉得原则应该是选择最近的“稳定”元素,选择最近是因为事件可以更快的冒泡上去,能够在第一时间进行处理。所谓“稳定”是指该父级元素是一开始就在页面上的,不是动态添加上来的,而且将来也不会消失掉,这样可以保证它可以时时监控着自己的孩子。

      4、on

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

    参数与delegate差不多但还是有细微的差别,首先type与selector换位置了,其次selector变为了可选项。

    $('#myol li').on('click',getHtml);

    可以看到event.currentTarget是li自己,与bind的效果一样。至于传selector进去,就是跟delegate一样的意义了,除了参数顺序不同,其他完全一样。

     
     
  • 相关阅读:
    系统CLOCK 频率 C代码查看范例
    LINUX C 文件读写范例
    linux 打印机 打印机支持工作组 openprinting
    问题记录
    初步了解profile文件
    内核中的HZ 及延迟等
    LINUX_System_Call_Quick_Reference
    Linux基础篇 六 (bash shell基础 (vi /etc/shells))
    Android调用平台功能具体技巧分享
    男人35岁前要做好的几件事
  • 原文地址:https://www.cnblogs.com/liyuspace/p/7715909.html
Copyright © 2011-2022 走看看