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

本文介绍了jQuery中bind、live、delegate和on四种事件绑定方式的差异,包括它们的使用场景、特点和适用版本。bind()在jQuery1.7后被on()取代,live()在1.9版本后不再支持,delegate()适用于jQuery1.4.2及以上版本,而on()从1.7版本开始引入,适用于当前和未来元素的事件绑定。在低版本jQuery中推荐使用delegate(),高版本则使用on()。
摘要由CSDN通过智能技术生成

前言

  因为项目中经常会有利用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必需;当绑定事件发生时,需要执行的函数;

举例说明

复制代码
 1 <html xmlns="http://www.w3.org/1999/xhtml">
 2 <head>
 3     <title>jquery中bind()绑定事件方式</title>
 4     <style type="text/css">
 5         .container
 6         {
    
 7             width: 300px;
 8             height: 300px;
 9             border: 1px #ccc solid;
10             background-color: Green;
11         }
12         .btn-test
13         {
    
14             border: 1px #ccc solid;
15             padding: 5px 15px;
16             cursor: pointer;
17         }
18     </style>
19     <script src="js/jquery-1.8.0.min.js" type="text/javascript"></script>
20     <script type="text/javascript">
21         $(function () {
22 
23             /*********添加单个事件处理*********/
24 
25             $(".btn-test").bind("click", function () {
26                 //显示隐藏div
27                 $(".container").slideToggle();
28             });
29 
30             /********添加多个事件处理********/
31 
32             //空格相隔方式
33             $(".btn-test").bind("mouseout click", function () {
34                 //显示隐藏div
35                 $(".container").slideToggle();
36             });
37 
38             //大括号替代方式
39             $(".btn-test").bind({
40                 "mouseout": function () {
41                     alert("这是mouseout事件!");
42                 },
43                 "click": function () {
44                     $(".container").slideToggle();
45                 }
46             });
47 
48             /********删除事件处理********/
49             $(".btn-test").unbind("click");
50 
51         });
52     </script>
53 </head>
54 <body>
55     <input type="button" value="按钮" class="btn-test" />
56     <div class="container">
57     </div>
58 </body>
59 </html>
复制代码

适用Jquery版本

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

live()

简要描述

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

使用方式

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值