一、原生JS事件绑定方法:

1、通过HTML属性进行事件处理函数的绑定如: 

<a href="#" onclick="f()">

2、通过JavaScript对象属性进行绑定:

var a=document.getElementById("a");
a.onclick=function(){alert("你好!")};//这里也可以不用匿名的函数直接赋方法名也是可以的

通过以上这种方式进行事件函数的绑定有个缺点就是只能对一个元素的一个事件绑定一个事件处理程序,如

document.body.onclick=function(){
alert("first.");
};
document.body.onclick=function(){
alert("second.");
};

以上这种方式后面的事件处理程序会将前面的覆盖只会执行alert("second"),前面的将不会被执行,如果要注册掉通过元素的属性注册的事件直接个事件属性赋值null即可移除绑定的事件函数,通过元素的属性注册的事件只能发生在事件的冒泡阶段。

3、利用所有文档元素的方法进行事件绑定:

a、addEventListener(type,handler,boolean),兼容IE以外的所有浏览器(所以IE浏览器是不能触发捕获阶段的事件的)

b、attachEvent(type,handler)适用于IE浏览器

另种方法可以为JS对象的一个类型事件注册多个事件处理程序,但两者是有区别的:

(1)addEventListener中的type是不带有on的如点击事件直接用"click",而在attachEvent中的type是需要带有前缀on的;(2)前者可以接收三个参数决定事件发生的阶段是在捕获阶段还是冒泡阶段,为true则发生在捕获阶段,如果为false则发生在冒泡阶段;(3)通过addEventListener注册的事件的执行顺序与事件的注册顺序一致,即先注册的先执行,后注册的后执行。而后者执行的顺序与注册的顺序是无关的,因而在写代码时代码的执行不要依赖事件的注册顺序。(4)addEventListener对于相同的事件只会注册一次,即使多次的写了注册函数也只会成功注册一个,而后者可以将将相同的事件处理函数注册多次,并且会多次被执行。

这两种方法通常会被同时应用用于兼容不同版本的浏览器。如:

if(ele.addEventListener())
{
ele.addEventListener("cilck",function(){alert("你好!")});
}
else {
ele.attachEvent("onclick",function(){alert("你好!");});
}

注销通过上述方法注册的事件的方法分别为:
removeEventListener(),detach(),在这两个方法中传入和上面一样的参数时就可以注销之前注册的事件,但是需要注意的是如果注册事件时事件处理函数的方法是匿名的则会无法注销即使将原方法传给注销事件函数。

二、jQuery中的注册事件处理函数的方法:(JQ中以下的几种绑定事件的方法咋JQ的源码中都是调用的on)

1、$(ele).bind(type,[data],hadler)

type:为事件类型,事件名称不需要加on

data:为可选参数,表示的时传入事件处理程序的参数

handler:注册的事件处理函数

bind()方法中可以给多个不同类型的事件注册同一事件处理程序:

$("a").bind('mouseenter mouseleave',f)

用空格将事件名隔开就好。

bind()方法可以给第一个参数参入一个对象这样可以一次为多个事件类型注册不同的事件处理程序:

$("a").bind('mouseleave.my',f)

bind()方法第一个参数type中可以带有命名空间用于指定给那个命名空间的这个类型事件绑定事件处理程序:

$("a").bind({mouseenter:f1,mouseleave:f2})

当引用多个命名空间时用该方法非常的有用,同时注销事件处理程序时也可以只注销指定命名空间的事件处理程序。

2、$(ele).on(type,selector,[data],handler)

该方法比bind方法多了一个参selector,该参数是用于对选定的元素进行过滤,元素队形中只有符合selector的才绑定该事件处理程序,其他参数同bind方法。该方法是目前应用最为广泛的。

3.$(ele).live(type,handler)

该方法直接将事件的监听器绑定到document对象上了,并没有直接绑定到元素上,元素对象触发事件后事件进行冒泡到docuemnt时才会执行相应的事件处理程序,这样做的好处是新添加的符合条件的元素对象无需在对形同类型的事件处理程序进行绑定,但这样同时会增加根节点的负担,因为所有元素对象的处理程序只有当时间冒泡到根节点时才会被执行,而且当子孙元素过多时,根节点可能将无法判断是哪个元素的请求而导致请求错误。

4、$(ele).delegate(selector,type,[data],handler)

该方法通过代理的方式解决了上面live代理到document的问,selector用于指定触发事件的元素,而调用该方法的元素对象将会成为事件的代理,即事件的监听器将会绑定到该元素对象上,这样就可以指定代理元素对象,不用将所有的事件监听器都绑定到document上。

以上几种注册事件的方法对应的注销事件方法分别为:

1、unbing()

a、带有一个参数时直接指定注销事件的类型名即可,有多个时用空格隔开:

$("a").bind({'click mouseleave'})

种种方法有个弊端当引用多个命名空间时会导致其他模块中钙元素对象相同事件类型的处理程序被注销掉了,因而可以利用命名空间的方式删除指定模块下的谁极爱你处理程序:

$("a").bind({'mouseenter.my'})

b、带有两个参数时:

$("a").bind('mouseenter',handler)

当同一事件类型注册有多个事件处理程序时,该方法可以只注销指定的石晶处理程序。

2、off()

3、die()

4、undelegate()

还有一些事件处理程序的绑定方法,如:one() 用于个元素对象绑定一次性事件处理程序,也就是绑定成功后该事件将只会被触发一次;toogle()该方法用于绑定点击事件处理函数,当传入多个函数时,第一次单击时执行死一个方法,第二次第二个,以此类推并循环;hover()用于同时给mouseenter、mouseleave事件绑定事件处理函数,当只传入一个方法时两者的处理函数相同,有两个时第一个是mouseenter的,另一个是mouseleave的和bind传对象时的一样功效。

$(ele).triggler/$(ele).fire这两个方法是用于触发事件的。

原生JS事件绑定方法以及jQuery绑定事件方法bind、live、on、delegate的区别的更多相关文章

  1. 原生JS添加节点方法与jQuery添加节点方法的比较及总结

    一.首先构建一个简单布局,来供下边讲解使用 1.HTML部分代码: <div id="div1">div1</div> <div id="d ...

  2. JS添加节点方法与JQuery添加节点方法的比较及总结

    原生JS添加节点方法与JQuery添加节点方法的比较及总结   一.首先构建一个简单布局,来供下边讲解使用 1.HTML部分代码: <div id="div1">div ...

  3. 原生JS—实现图片循环切换的两种方法

    今天我们主要讲讲如何使用原生JS实现图片的循环切换的方法.多余的话我们就不多说了,我们一个一个开始讲吧. 1  原生JS实现图片循环切换 -- 方法一 在上栗子之前我们先简单介绍一下所用的一些知识点. ...

  4. 原生js实现 vue的数据双向绑定

    原生js实现一个简单的vue的数据双向绑定 vue是采用数据劫持结合发布者-订阅者模式的方式,通过Object.defineProperty()来劫持各个属性的setter,getter,在数据变动时 ...

  5. 原生js获取宽高与jquery获取宽高的方法的关系

    说明:1.因为获取高度的情况跟获取宽度的情况一样,所以以下只说获取宽度的情况.  2.以下所说的所有方法与属性所返回的值都是不带单位的.  3.为了方便说明,以下情况采用缩写表示:  obj -> ...

  6. 原生JS的使用,包括jquery和原生JS获取节点、jquery和原生JS修改属性的比较

    一.前言 相比于JS这条直达终点.满是荆棘的小路,jquery无疑是康庄大道了,足够的简洁.易用给了它辉煌的地位.然而,毕竟是绕着道的插件,当小路走着走着变成大路的时候,曾经的大路也就失去了他自身的优 ...

  7. MVC异步AJAX的三种方法(JQuery的Get方法、JQuery的Post方法和微软自带的异步方法)

    异步是我们在网站开发过程中必不可少的方法,MVC框架的异步方法也有很多,这里介绍三种方法: 一.JQuery的Get方法 view @{ Layout = null; } <!DOCTYPE h ...

  8. 原生js中如果有多个onload事件解决方案

    在一个页面中有两个JavaScript 分别都用到了window.onload 一个是:window.onload=func1,另一个是:window.onload=func2 这样就造成了一个Jav ...

  9. 原生JS获取HTML DOM元素的8种方法

    JS获取DOM元素的方法(8种) 通过ID获取(getElementById) 通过name属性(getElementsByName) 通过标签名(getElementsByTagName) 通过类名 ...

随机推荐

  1. Java JVM类加载机制

    虚拟机的类加载机制是:JVM把描述类的数据从.class文件加载到内存,并对数据进行校验.解析.初始化,最终形成可以被JVM直接使用的Java类型. 加载.连接(验证.准备.解析).初始化.使用.卸载 ...

  2. Hibernate POJO在序列化(JSON)时遇到的若干问题

    假设某 POJO 有属性如下: private Set<User> users = new HashSet<>(0); @OneToMany(fetch = FetchType ...

  3. Python~recursive function递归函数

    尾递归实现循环 def fact(n): if n==1: return 1 else : return n * fact(n-1) raw_input() 字符而非数字 unsupported op ...

  4. K3中间层配置不成功 kdsvrmgr组件不工作 问题 客户端需要检查的设置

    苏州K3刘保平电脑安装的K3装有中间层组件,导致中间层死配都配不成功  以后中间层配置不成功的时候除了检查能否访问K3服务器之外,还要检查一下是否安装了中间层http://wenku.baidu.co ...

  5. nginx笔记资料

    通配 hash 表 ngx_hash_init 实现注释:http://blog.csdn.net/gsnumen/article/details/7817396 ngx_hash_init之后的结构 ...

  6. Assertion failure in -[UITableView _configureCellForDisplay:forIndexPath:]

    今天遇到了Assertion failure in -[UITableView _configureCellForDisplay:forIndexPath:]这个错误,一直也没有百度,不料想却弄了一个 ...

  7. 低功耗蓝牙BLE之连接事件、连接参数和更新方法

    转自:http://blog.csdn.net/zzfenglin/article/details/51304084 连接事件 在一个连接当中,主设备会在每个连接事件里向从设备发送数据包.一个连接事件 ...

  8. Android开发环境(IDE)

    一:Eclipse 1.装JDK: 2.装Eclipse://应与JDK同为32/64位. 3.装ADT: 4.装android sdk: 推荐下载ADT bundle包(包含Eclipse,Andr ...

  9. STL set 用法

      c++ stl集合set介绍 c++ stl集合(Set)是一种包含已排序对象的关联容器.set/multiset会根据待定的排序准则,自动将元素排序.两者不同在于前者不允许元素重复,而后者允许. ...

  10. Python爬虫学习(6): 爬取MM图片

    为了有趣我们今天就主要去爬取以下MM的图片,并将其按名保存在本地.要爬取的网站为: 大秀台模特网 1. 分析网站 进入官网后我们发现有很多分类: 而我们要爬取的模特中的女模内容,点进入之后其网址为:h ...