从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()一样的效果。
     
    jQuery1.9已经删除了live api,推荐大家用.on()挂载事件处理函数.
    .live()的几个缺陷:
    (1)耗时
    (2)不能串起来用, For example, $(“a”).find(“.offsite, .external”).live( … ); 这个是不行的
    (3)还是耗时
    (4)使用.live()时,event.stopPropagation()无效
    (5)可能出现意外结果

    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.
            });
         
    貌似第一个和第二个参数的顺序颠倒了一下,别的基本一样。