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 相关文章推荐
怎么让脚本或里面的函数在所有图片都载入完毕的时候执行
Oct 17 Javascript
JavaScript中的16进制字符(改进)
Nov 21 Javascript
JavaScript 学习笔记之一jQuery写法图片等比缩放以及预加载
Jun 28 Javascript
基于jquery异步传输json数据格式实例代码
Nov 23 Javascript
JS实现跟随鼠标闪烁转动色块的方法
Feb 26 Javascript
JavaScript 随机验证码的生成实例代码
Sep 22 Javascript
JSON键值对序列化和反序列化解析
Jan 24 Javascript
js实现图片加载淡入淡出效果
Apr 07 Javascript
vue-cli3搭建项目的详细步骤
Dec 05 Javascript
微信小程序实现的绘制table表格功能示例
Apr 26 Javascript
微信小程序获取当前位置和城市名
Nov 13 Javascript
vue实现自定义多选按钮
Jul 16 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
模拟xcopy的函数
2006/10/09 PHP
php 在线打包_支持子目录
2008/06/28 PHP
PHP自定义函数实现格式化秒的方法
2016/09/14 PHP
php中preg_replace正则替换用法分析【一次替换多个值】
2017/01/17 PHP
Vagrant(WSL)+PHPStorm+Xdebu 断点调试环境搭建
2019/12/13 PHP
jQuery$命名冲突怎么办如何解决
2014/01/16 Javascript
jquery取消选择select下拉框示例代码
2014/02/22 Javascript
JavaScript代码复用模式详解
2014/11/07 Javascript
Node.js 制作实时多人游戏框架
2015/01/08 Javascript
javascript二维数组转置实例
2015/01/22 Javascript
jquery通过load获取文件的内容并跳到锚点的方法
2015/01/29 Javascript
vue.js通过自定义指令实现数据拉取更新的实现方法
2016/10/18 Javascript
微信小程序 定义全局数据、函数复用、模版等详细介绍
2016/10/27 Javascript
理解javascript中的闭包
2017/01/11 Javascript
微信小程序左右滑动切换页面详解及实例代码
2017/02/28 Javascript
使用 NodeJS+Express 开发服务端的简单介绍
2017/04/07 NodeJs
webpack配置的最佳实践分享
2017/04/21 Javascript
Bootstrap多级菜单的实现代码
2017/05/23 Javascript
JavaScript变量作用域_动力节点Java学院整理
2017/06/27 Javascript
Angular4如何自定义首屏的加载动画详解
2017/07/26 Javascript
微信小程序 页面跳转事件绑定的实例详解
2017/09/20 Javascript
vue2.0+vuex+localStorage代办事项应用实现详解
2018/05/31 Javascript
Vue 全家桶实现移动端酷狗音乐功能
2018/11/16 Javascript
在 Vue.js中优雅地使用全局事件的方法
2019/02/01 Javascript
JavaScript变速动画函数封装添加任意多个属性
2019/04/03 Javascript
vue发送websocket请求和http post请求的实例代码
2019/07/11 Javascript
利用Angular7开发一个Radio组件的全过程
2019/07/11 Javascript
对TypeScript库进行单元测试的方法
2019/07/18 Javascript
jQuery Ajax async=&gt;false异步改为同步时,解决导致浏览器假死的问题
2019/07/22 jQuery
Vue如何获取数据列表展示
2019/12/11 Javascript
python去除空格和换行符的实现方法(推荐)
2017/01/04 Python
Python 使用 attrs 和 cattrs 实现面向对象编程的实践
2019/06/12 Python
世界领先的艺术图书出版社:TASCHEN
2018/07/23 全球购物
党的群众路线教育实践活动领导班子整改方案
2014/10/25 职场文书
教师党员学习群众路线心得体会
2014/11/04 职场文书
公司酒会主持词
2015/07/02 职场文书