JavaScript事件一共有三种监听方法分别如下:

1、事件监听一夹杂在html标签内

 <div id="box" onClick="alert('HELLO WORLD')">
<div id="box2" onClick="notice();"></div>
<div id="box3" onClick="service('HELLO WORLD'');"></div>
</div> function notice(){ alert(HELLO WORLD'");}
function service(str){ alert(str);}

说明:以上把事件监听功能onClick写到div中的形式是最古老原始形式,所有主流浏览器都支持。

类似行内CSS样式一样,是有效的(注意大小敏感),但是缺点和写到行内的CSS样式一样。

优点:

1)兼容性好,基本上所有浏览器都支持该种方式

缺点如下:

 1)复用性不好。

 2)JS与HTML夹杂到一块,代码混乱,发生错误难以检测和排除,不利于分工合作。

 3)如果发生修改需要同时修改HTML和JS,改动相对困难。

为了解决以上问题把事件监听形式改进如下,以下方式也是目前主流的使用方式之一。

2、事件监听方法二 on+"事件"

 <div id="box"></div>

 var box = document.getElementById("box");

 box.onclick = function(){
alert("HELLOW WORLD");
};

说明:通过以上形式可以把事件与HTML完全分离,是最常用的形式之一。

以上对于一般项目已经足够用。但如果想单击一次执行多个函数时,这种绑定方式就无法完成了:

 box.onclick = function(){
fnA();
fnB();
};
function fnA(){
alert("我会被执行");
}
function fnB(){
alert("我也会被执行");
}

说明:这种情况下 alert("HELLOW WORLD") 就不会被执行了,也就是说后面的函数覆盖了之前声明的函数。

优点:

1)兼容性好,基本支持所有浏览器

2)做到了文档与JS的分离,方便后期的代码管理

缺点:

1)同一个事件,在执行多个函数时会发生覆盖

3、事件监听方法三 element.addEventListener(事件名,函数,冒泡/捕获)

<div id="box">
<div id="box1"></div>
<div id="box2"></div>
</div> var box = document.getElementById("box");
box.addEventListener("click",fnA,false);
box.addEventListener("click",fnB,false); function fnA(){
alert("HELLO WORLD!");
}
function fnB(){
alert("HI CHINA!");
}

上面两个函数fA(),fB()都会执行,不会发生覆盖现象。

使用介绍:

addEventListene是DOM2的标准语法,新版本主流浏览器基本都支持。但是老版本IE浏览器不支持;

这种绑定方法有三个参数:

第一个是事件类型,不需要on前缀,但事件名需加  " " ;
第二个参数是发生这个事件的时候要调用的函数;

第三个是布尔值的true或false.(默认值是false)
false代码是以冒泡型事件流进行处理,一般都选用false.
true意味着代码以捕获型事件流进行处理,不是必须不推荐使用。

优点:

1)做到JS与HTML文档分离,便于代码维护;

2)不会发生像on+"事件"的函数覆盖现象;

3)提供监听的事件以冒泡或者捕获的可选方式执行

缺点:

1)兼容性还不完善,老板IE浏览器可能不兼容;

2)方法名较长,记忆稍有难度

:使用element.removeEventListener(type,listener,useCapture);方法可以移除已经添加的实际。
        使用方法:box.removeEventListener("click",fnB,false);

4、IE浏览器的特性型:

老版本IE浏览器有自己的方法 attachEvent和detachEvent.
语法格式如下:
element.attachEvent("onclick",listenerFunction) //添加事件
element.detachEvent("onclick",listenerFunction) //删除事件

js基础——事件绑定(事件监听)的更多相关文章

  1. node.js 基础二 开启服务器监听

    1.server.js 2.监听 一 server.js 二 监听 运行server.js后,浏览器打开:http://localhost:8888/ //====================== ...

  2. node之events 模块,并通过实例化 EventEmitter 类来绑定和监听事件

    例子来源:http://www.runoob.com/nodejs/nodejs-event-loop.html http://www.runoob.com/nodejs/nodejs-event.h ...

  3. 使用 JS 关闭警告框及监听自定义事件(amaze ui)

    使用 JS 关闭警告框及监听自定义事件(amaze ui) 一.总结 1.jquery匿名函数:第8行,jquery匿名函数,$(function(){});,有没有很简单,只是少了jquery的前面 ...

  4. JS与JQ绑定事件的几种方式.

    JS与JQ绑定事件的几种方式 JS绑定事件的三种方式 直接在DOM中进行绑定 <button onclick="alert('success')" type="bu ...

  5. Spring事件发布与监听机制

    我是陈皮,一个在互联网 Coding 的 ITer,微信搜索「陈皮的JavaLib」第一时间阅读最新文章,回复[资料],即可获得我精心整理的技术资料,电子书籍,一线大厂面试资料和优秀简历模板. 目录 ...

  6. 关于JAVA中事件分发和监听机制实现的代码实例-绝对原创实用

    http://blog.csdn.net/5iasp/article/details/37054171 文章标题:关于JAVA中事件分发和监听机制实现的代码实例 文章地址: http://blog.c ...

  7. Pox启动及事件产生、监听分析

        ./pox/pox.py , Pox       实例化core=pox.core.initialize(),即为实例化POXCore类(该类是所有组件的交接点,提供组件注册功能),监听cor ...

  8. JavaEE开发之Spring中的事件发送与监听以及使用@Profile进行环境切换

    本篇博客我们就来聊一下Spring框架中的观察者模式的应用,即事件的发送与监听机制.之前我们已经剖析过观察者模式的具体实现,以及使用Swift3.0自定义过通知机制.所以本篇博客对于事件发送与监听的底 ...

  9. Spring知识点回顾(07)事件发布和监听

    Spring知识点回顾(07)事件发布和监听 1.DemoEvent extends ApplicationEvent { public DemoEvent(Object source, String ...

  10. spring 自定义事件发布及监听(简单实例)

    前言: Spring的AppilcaitionContext能够发布事件和注册相对应的事件监听器,因此,它有一套完整的事件发布和监听机制. 流程分析: 在一个完整的事件体系中,除了事件和监听器以外,还 ...

随机推荐

  1. tomcat 内存溢出问题(OutOfMemoryError: PermGen space)

    导入公司项目的时候出现的问题,在此记录处理方法. tomcat在启动的时候报错:OutOfMemoryError: PermGen space PermGen space的全称是Permanent G ...

  2. 修改struts2自定义标签的源代码,在原有基础上增加功能(用于OA项目权限判断,是否显示某个权限)

    OA项目在做权限判断时  原始方式: 现在完成的功能 :通过改变struts2自定标签源代码   在原有的基础上  增加判断权限的功能  而页面上使用标签的方式 还是下图 步骤: 打开文件 搜索< ...

  3. centos: git clone提示Permission denied publickey 问题

    问题: Initialized empty Git repository in /data1/mouxuan/fastsocket-private/.git/ Permission denied (p ...

  4. [Ionic] Align and Size Text with Ionic CSS Utilities

    The Ionic framework provides several built-in CSS Utilities or directives that you can leverage when ...

  5. 【Hibernate步步为营】--单向关联一对一映射

    上篇文章对多对一的关联映射做了具体的分析,它在实现上能够有两种方式,而且这两种方式实现也非常easy,关键是标签<many-to-one>的使用,它分别指明了多端和一端的映射关系.这样的映 ...

  6. Android学习笔记之ProgressBar案例分析

    (1) <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:to ...

  7. h5-news_index

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAdcAAABuCAIAAAD6VM6fAAAUEUlEQVR4nO2dfXRTZZ7Hfx735Z/lr9 ...

  8. 0x36 组合计数

    组合计算的性质: C(n,m)= m! / (n!(m-n)!) C(n,m)=C(m-n,m); C(n,m)=C(n,m-1)+C(n-1,m-1); 二项式定理:(a+b)^n=sigema(k ...

  9. numpy的scale就是 x-mean/std

    >>> from sklearn import preprocessing >>> import numpy as np >>> a=np.arr ...

  10. 【转】小白级的CocoaPods安装和使用教程

    原文网址:http://www.jianshu.com/p/e2f65848dddc 百度有很多CocoaPods的安装教程.第一次看的时候,确实有点摸不透的感觉.经过思考,一步一步来实践,前后花了三 ...