jQuery中bind(),live(),delegate(),on()绑定事件方法实例详解


Posted in Javascript onJanuary 19, 2016

本文实例分析了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:必需;当绑定事件发生时,需要执行的函数;

举例说明

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>jquery中bind()绑定事件方式</title>
  <style type="text/css">
    .container
    {
      width: 300px;
      height: 300px;
      border: 1px #ccc solid;
      background-color: Green;
    }
    .btn-test
    {
      border: 1px #ccc solid;
      padding: 5px 15px;
      cursor: pointer;
    }
  </style>
  <script src="js/jquery-1.8.0.min.js" type="text/javascript"></script>
  <script type="text/javascript">
    $(function () {
      /*********添加单个事件处理*********/
      $(".btn-test").bind("click", function () {
        //显示隐藏div
        $(".container").slideToggle();
      });
      /********添加多个事件处理********/
      //空格相隔方式
      $(".btn-test").bind("mouseout click", function () {
        //显示隐藏div
        $(".container").slideToggle();
      });
      //大括号替代方式
      $(".btn-test").bind({
        "mouseout": function () {
          alert("这是mouseout事件!");
        },
        "click": function () {
          $(".container").slideToggle();
        }
      });
      /********删除事件处理********/
      $(".btn-test").unbind("click");
    });
  </script>
</head>
<body>
  <input type="button" value="按钮" class="btn-test" />
  <div class="container">
  </div>
</body>
</html>

适用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:必需;当绑定事件发生时,需要执行的函数;

举例说明

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>jquery中live()绑定事件方式</title>
  <style type="text/css">
    .container
    {
      width: 300px;
      height: 300px;
      border: 1px #ccc solid;
      background-color: Green;
    }
    .btn-test
    {
      border: 1px #ccc solid;
      padding: 5px 15px;
      cursor: pointer;
    }
  </style>
  <script src="js/jquery-1.8.0.min.js" type="text/javascript"></script>
  <script type="text/javascript">
    $(function () {
      /*********添加单个事件处理*********/
      $(".btn-test").live("click", function () {
        //显示隐藏div
        $(".container").slideToggle();
      });
      /********添加多个事件处理********/
      //空格相隔方式
      $(".btn-test").live("mouseout click", function () {
        //显示隐藏div
        $(".container").slideToggle();
      });
      //大括号替代方式
      $(".btn-test").live({
        "mouseout": function () {
          alert("这是mouseout事件!");
        },
        "click": function () {
          $(".container").slideToggle();
        }
      });
      /********删除事件处理********/
      $(".btn-test").die("click");
    });
  </script>
</head>
<body>
  <input type="button" value="按钮" class="btn-test" />
  <div class="container">
  </div>
</body>
</html>

适用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:必需;当绑定事件发生时,需要执行的函数;

举例说明

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>jquery中delegate()绑定事件方式</title>
  <style type="text/css">
    .container
    {
      width: 300px;
      height: 300px;
      border: 1px #ccc solid;
      background-color: Green;
    }
    .btn-test
    {
      border: 1px #ccc solid;
      padding: 5px 15px;
      cursor: pointer;
    }
  </style>
  <script src="js/jquery-1.8.0.min.js" type="text/javascript"></script>
  <script type="text/javascript">
    $(function () {
      /***********单元素添加单事件***********/
      //按钮绑定单击事件 实现div的显示隐藏
      $(".header").delegate("#btn-test1", "click", function () {
        $(".container").slideToggle();
      });
      /***********单元素添加多事件***********/
      //空格相隔方式
      $(".header").delegate("#btn-test1", "click mouseout", function () {
        $(".container").slideToggle();
      });
      //大括号替代方式
      $(".header").delegate("#btn-test1", {
        "mouseout": function () {
          alert("这是mouseout事件!");
        },
        "click": function () {
          $(".container").slideToggle();
        }
      });
    });
  </script>
</head>
<body>
  <div class="header">
    <input type="button" value="按钮1" class="btn-test" id="btn-test1" />
    <input type="button" value="按钮2" class="btn-test" id="btn-test2" />
  </div>
  <div class="container">
  </div>
</body>
</html>

适用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:必需;当绑定事件发生时,需要执行的函数;

举例说明

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>jquery中on()绑定事件方式</title>
  <style type="text/css">
    .container
    {
      width: 300px;
      height: 300px;
      border: 1px #ccc solid;
      background-color: Green;
    }
    .btn-test
    {
      border: 1px #ccc solid;
      padding: 5px 15px;
      cursor: pointer;
    }
  </style>
  <script src="js/jquery-1.8.0.min.js" type="text/javascript"></script>
  <script type="text/javascript">
    $(function () {
      /*********添加单个事件处理*********/
      $(".header").on("click", ".btn-test", function () {
        //显示隐藏div
        $(".container").slideToggle();
      });
      /********添加多个事件处理********/
      //空格相隔方式
      $(".header").on("mouseout click", ".btn-test", function () {
        //显示隐藏div
        $(".container").slideToggle();
      });
      //大括号替代方式
      $(".header").on({
        "mouseout": function () {
          alert("这是mouseout事件!");
        },
        "click": function () {
          $(".container").slideToggle();
        }
      }, ".btn-test");
      //删除事件
      $(".header").off("click", ".btn-test");
    });
  </script>
</head>
<body>
  <div class="header">
    <input type="button" value="按钮" class="btn-test" />
  </div>
  <div class="container">
  </div>
</body>
</html>

适用Jquery版本

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

五、四种方式的异同和优缺点

相同点:

1.都支持单元素多事件的绑定;空格相隔方式或者大括号替代方式;
2.均是通过事件冒泡方式,将事件传递到document进行事件的响应;

比较和联系:

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

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>jquery中四种方式给未来元素设置事件</title>
  <style type="text/css">
    .container
    {
      width: 300px;
      height: 300px;
      border: 1px #ccc solid;
      background-color: Green;
    }
    .btn-test
    {
      border: 1px #ccc solid;
      padding: 5px 15px;
      cursor: pointer;
    }
  </style>
  <script src="js/jquery-1.8.0.min.js" type="text/javascript"></script>
  <script type="text/javascript">
    $(function () {
      //利用bind()方法,给P标签设置click方法  ======失败 没有任何反应=======
      $(".container p").bind("click", function () {
        alert("bind()添加单击事件成功!");
      });
      //利用live()方法.给P标签设置click方法  =======成功调用方法============
      $(".container p").live("click", function () {
        alert("live()添加单击事件成功!");
      });
      //利用delegate()方法.给P标签设置click方法 =======成功调用方法============
      $(".container").delegate("p", "click", function () {
        //显示隐藏div
        alert("delegate()添加单击事件成功!");
      });
      //利用on()方法.给P标签设置click方法 =======成功调用方法============
      $(".container").on("click", "p", function () {
        //显示隐藏div
        alert("on()添加单击事件成功!");
      });
      //按钮添加P标签
      $(".btn-test").click(function () {
        $(".container").append("<p>这是新增的段落!</p>");
      });
    });
  </script>
</head>
<body>
  <input type="button" class="btn-test" value="添加元素" />
  <div class="container">
  </div>
</body>
</html>

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

3.live()函数和delegate()函数两者类似,但是live()函数在执行速度,灵活性和CSS选择器支持方面较delegate()差些,想了解具体情况,请参考这篇《jQuery中的.bind()、.live()和.delegate()之间区别分析》

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

六、总结

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

希望本文所述对大家jQuery程序设计有所帮助。

Javascript 相关文章推荐
JS在IE和FireFox之间常用函数的区别小结
Mar 12 Javascript
jQuery 技巧小结
Apr 02 Javascript
Node.js异步I/O学习笔记
Nov 04 Javascript
jQuery插件开发汇总
May 15 Javascript
实用jquery操作表单元素的简单代码
Jul 04 Javascript
javascript中获取元素标签中间的内容的实现方法
Oct 08 Javascript
JS+HTML5 FileReader对象用法示例
Apr 07 Javascript
BootStrap的两种模态框方式
May 10 Javascript
详解如何webpack使用DllPlugin
Sep 30 Javascript
微信小程序与公众号卡券/会员打通的问题
Jul 25 Javascript
Vue开发环境跨域访问问题
Jan 22 Javascript
Vue插槽_特殊特性slot,slot-scope与指令v-slot说明
Sep 04 Javascript
学习JavaScript设计模式之装饰者模式
Jan 19 #Javascript
jQuery事件绑定用法详解(附bind和live的区别)
Jan 19 #Javascript
浏览器环境下JavaScript脚本加载与执行探析之动态脚本与Ajax脚本注入
Jan 19 #Javascript
js实现有过渡渐变效果的图片轮播相册(兼容IE,ff)
Jan 19 #Javascript
jquery 重写 ajax提交并判断权限后 使用load方法报错解决方法
Jan 19 #Javascript
学习JavaScript设计模式之享元模式
Jan 18 #Javascript
纯JavaScript基于notie.js插件实现消息提示特效
Jan 18 #Javascript
You might like
linux下 C语言对 php 扩展
2008/12/14 PHP
PHP 字符串加密函数(在指定时间内加密还原字符串,超时无法还原)
2010/04/28 PHP
PHP使用标准库spl实现的观察者模式示例
2018/08/04 PHP
PHP设计模式概论【概念、分类、原则等】
2020/05/01 PHP
csdn 博客的css样式 v3
2009/02/24 Javascript
javascript 打印页面代码
2009/03/24 Javascript
js压缩工具 yuicompressor 使用教程
2010/03/31 Javascript
有道JavaScript监听浏览器的问题
2010/06/23 Javascript
使用JQUERY进行后台页面布局控制DIV实现左右式
2014/01/07 Javascript
jquery清空表单数据示例分享
2014/02/13 Javascript
js 金额格式化来回转换示例
2014/02/23 Javascript
JavaScript字符串删除重复字符的方法
2015/12/25 Javascript
网页中JS函数自动执行常用三种方法
2016/03/30 Javascript
浅谈js内置对象Math的属性和方法(推荐)
2016/09/19 Javascript
Bootstrap图片轮播组件Carousel使用方法详解
2016/10/20 Javascript
webpack学习教程之publicPath路径问题详解
2017/06/17 Javascript
[01:19:33]DOTA2-DPC中国联赛 正赛 iG vs VG BO3 第一场 2月2日
2021/03/11 DOTA
如何准确判断请求是搜索引擎爬虫(蜘蛛)发出的请求
2015/10/13 Python
Python基于TCP实现会聊天的小机器人功能示例
2018/04/09 Python
python 3.6.4 安装配置方法图文教程
2018/09/18 Python
python2与python3的print及字符串格式化小结
2018/11/30 Python
Python使用sax模块解析XML文件示例
2019/04/04 Python
Python实现字典按key或者value进行排序操作示例【sorted】
2019/05/03 Python
利用Pandas和Numpy按时间戳将数据以Groupby方式分组
2019/07/22 Python
python同时替换多个字符串方法示例
2019/09/17 Python
Python列表原理与用法详解【创建、元素增加、删除、访问、计数、切片、遍历等】
2019/10/30 Python
python利用xlsxwriter模块 操作 Excel
2020/10/14 Python
python lambda的使用详解
2021/02/26 Python
美国最大和最受信任的二手轮胎商店:Bestusedtires.com
2020/06/02 全球购物
关于逃课的检讨书
2014/01/23 职场文书
经典婚礼主持词
2014/03/13 职场文书
2014年民政局关于保密工作整改措施
2014/09/19 职场文书
2014年电信员工工作总结
2014/12/19 职场文书
2015年团支部工作总结
2015/04/03 职场文书
六五普法先进个人主要事迹材料
2015/11/03 职场文书
MongoDB支持的索引类型
2022/04/11 MongoDB