• Jquery中的bind(),live(),delegate(),on()绑定事件方式


    Jquery中的bind(),live(),delegate(),on()绑定事件方式

    前言

      因为项目中经常会有利用jquery操作dom元素的增删操作,所以会涉及到dom元素的绑定事件方式,简单的归纳一下bind,live,delegate,on的区别,以便以后查阅,也希望该文章日后能帮助到园友,文中如有不当之处,还望各位指正,话不多说,直接进入正题。

    bind()

    简要描述

      bind()向匹配元素添加一个或多个事件处理器。

    使用方式

      $(selector).bind(event,data,function)

      event必需项;添加到元素的一个或多个事件,例如 click,dblclick等;

              单事件处理:例如 $(selector).bind("click",data,function);

              多事件处理:1.利用空格分隔多事件,例如 $(selector).bind("click dbclick mouseout",data,function);

                    2.利用大括号灵活定义多事件,例如 $(selector).bind({event1:function, event2:function, ...}) 

                    3.空格相隔方式:绑定较为死板,不能给事件单独绑定函数,适合处理多个事件调用同一函数情况;

                     大括号替代方式:绑定较为灵活,可以给事件单独绑定函数;     

      data可选;需要传递的参数;

      function必需;当绑定事件发生时,需要执行的函数;

    举例说明

     View Code

    适用Jquery版本

      适用所有版本,但是根据官网解释,自从jquery1.7版本以后bind()函数推荐用on()来代替。

    live()

    简要描述

      live() 当前或未来的匹配元素添加一个或多个事件处理器;

    使用方式

      $(selector).live(event,data,function)

      event:必需项;添加到元素的一个或多个事件,例如 click,dblclick等;

          单事件处理:例如 $(selector).live("click",data,function);

          多事件处理:1.利用空格分隔多事件,例如 $(selector).live("click dbclick mouseout",data,function);

                2.利用大括号灵活定义多事件,例如 $(selector).live({event1:function, event2:function, ...}) 

                3.空格相隔方式:绑定较为死板,不能给事件单独绑定函数,适合处理多个事件调用同一函数情况;

                   大括号替代方式:绑定较为灵活,可以给事件单独绑定函数;     

      data:可选;需要传递的参数;

      function:必需;当绑定事件发生时,需要执行的函数;

    举例说明

     View Code

    适用Jquery版本

      jquery1.9版本以下支持,jquery1.9及其以上版本删除了此方法,jquery1.9以上版本用on()方法来代替。

    delegate()

    简要描述

      delegate() 为指定的元素(被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数。使用 delegate() 方法的事件处理程序适用于当前或未来的元素(比如由脚本创建的新元素)。

    使用方式 

      $(selector).delegate(childSelector,event,data,function)

      childSelector: 必需项;需要添加事件处理程序的元素,一般为selector的子元素;

      event:必需项;添加到元素的一个或多个事件,例如 click,dblclick等;

          单事件处理:例如 $(selector).delegate(childselector,"click",data,function);

          多事件处理:1.利用空格分隔多事件,例如 $(selector).delegate(childselector,"click dbclick mouseout",data,function);

                2.利用大括号灵活定义多事件,例如 $(selector).delegate(childselector,{event1:function, event2:function, ...}) 

                3.空格相隔方式:绑定较为死板,不能给事件单独绑定函数,适合处理多个事件调用同一函数情况;

                   大括号替代方式:绑定较为灵活,可以给事件单独绑定函数;     

      data:可选;需要传递的参数;

      function:必需;当绑定事件发生时,需要执行的函数;

    举例说明

     View Code

    适用Jquery版本

      jquery1.4.2及其以上版本;

    on()

    简要描述

      on() 为指定的元素,添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数。使用 on() 方法的事件处理程序适用于当前或未来的元素(比如由脚本创建的新元素)。

    使用方式 

      $(selector).on(event,childselector,data,function)

      event:必需项;添加到元素的一个或多个事件,例如 click,dblclick等;

          单事件处理:例如 $(selector).on("click",childselector,data,function);

          多事件处理:1.利用空格分隔多事件,例如 $(selector).on("click dbclick mouseout",childseletor,data,function);

                2.利用大括号灵活定义多事件,例如 $(selector).on({event1:function, event2:function, ...},childselector); 

                3.空格相隔方式:绑定较为死板,不能给事件单独绑定函数,适合处理多个事件调用同一函数情况;

                   大括号替代方式:绑定较为灵活,可以给事件单独绑定函数; 

      childSelector: 可选;需要添加事件处理程序的元素,一般为selector的子元素;    

      data:可选;需要传递的参数;

      function:必需;当绑定事件发生时,需要执行的函数;

    举例说明

     View Code

    适用Jquery版本

      jquery1.7及其以上版本;jquery1.7版本出现之后用于替代bind(),live()绑定事件方式;

    四种方式的异同和优缺点

    相同点:

      1.都支持单元素多事件的绑定;空格相隔方式或者大括号替代方式;

      2.均是通过事件冒泡方式,将事件传递到document进行事件的响应;

    比较和联系:

    1.bind()函数只能针对已经存在的元素进行事件的设置;但是live(),on(),delegate()均支持未来新添加元素的事件设置;演示代码如下:

     View Code

    2.bind()函数在jquery1.7版本以前比较受推崇,1.7版本出来之后,官方已经不推荐用bind(),替代函数为on(),这也是1.7版本新添加的函数,同样,可以

     用来代替live()函数,live()函数在1.9版本已经删除;

    3.live()函数和delegate()函数两者类似,但是live()函数在执行速度,灵活性和CSS选择器支持方面较delegate()差些,想了解具体情况,请戳这:

     http://kb.cnblogs.com/page/94469/

    4.bind()支持Jquery所有版本;live()支持jquery1.8-;delegate()支持jquery1.4.2+;on()支持jquery1.7+; 

    总结

       

      如果项目中引用jquery版本为低版本,推荐用delegate(),高版本jquery可以使用on()来代替,以上仅为个人看法,如有不同想法,欢迎拍砖交流。

     
    分类: JQuery
    标签: bind()delegate()on()live()
  • 相关阅读:
    牛客网 二叉树的镜像 JAVA
    牛客网 反转链表 JAVA
    牛客网 调整数组顺序使奇数位于偶数前面 JAVA
    Integer to Roman LeetCode Java
    Valid Number leetcode java
    Longest Common Prefix
    Wildcard Matching leetcode java
    Regular Expression Matching
    Longest Palindromic Substring
    Add Binary LeetCode Java
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/4110474.html
Copyright © 2020-2023  润新知