一 扭转对事件的认知

事件,是js和html交互的桥梁。当用户操作页面上的元素,比如点击,鼠标移入移出,然后做一些事情。

你若触发,我便执行——事件发生,调用它的处理函数执行相应的JavaScript代码给出响应。

在页面放一个元素:

<input type="button" id="btn" />

以onclick为例:

var oBtn = document.getElementById("btn"); //获得按钮的引用
//用for in打印出对象上的属性名
for(var i in oBtn){
console.log(i);
}

在控制台,可以看到,onclick作为元素对象的属性存在:

再打印出onclick得值:

console.log(oBtn["onclick"]); //null

当在页面中写一个元素的时候,这个元素本身就有事件存在,并不是给元素添加事件,而是添加事件处理函数。不给元素的事件指定相应的事件处理函数,作为对象的特殊属性,事件对应的值为null,则在页面中再怎么点也毫无反应。

当添加了事件处理函数:

oBtn.onclick = function(){alert("onclick");};

或:

function clicnFn(){alert("clicnFn1");}
oBtn.onclick = clicnFn;

点击页面button会执行赋给点击事件的处理函数,弹出clicnFn1。

Note:不要认为是给元素添加了事件,只是给元素的事件添加了事件处理函数而已。

二 事件绑定

当在同一个元素同一事件添加不同的处理函数,如:

function clicnFn1(){alert("clicnFn1");}
function clicnFn2(){alert("clicnFn2");}
oBtn.onclick = clicnFn1;
oBtn.onclick = clicnFn2;

点击按钮,只会弹出clicnFn2,因为下面的赋值会覆盖上面的赋值。

那怎么解决呢?答案是使用事件绑定

在标准浏览器(FF,chrome,ie9+),使用addEventListener,使用方法:

addEventListener(事件名,事件处理函数,布尔值);

第三个参数为布尔值,false是冒泡时触发,true为捕获时触发,通常设为false。

除非想在到达事件目标之前,想做点事,那么设为true。(关于冒泡和捕获,会在事件流中详细讲解)

在ie低版本浏览器(ie6/7/8),使用attachEvent,使用方法:

atttachEvent(事件名,事件处理函数);

ie低版本浏览器不支持捕获,只支持冒泡。

封装兼容写法addEvent函数:

/*
@fileOverview 对事件绑定的兼容封装
@param {oBject} 元素对象
@param {String} 事件名
@param {Function} 事件处理函数
*/
function addEvent(obj,eventName,fn){
if(obj.attachEvent){
obj.attachEvent("on"+eventName,function(){ //在ie低版本中,需要在事件名前加上on
//在ie中事件绑定的处理函数this指向的window,需要用call将this指向obj,以便在事件处理函数中使用this
fn.call(obj);
});
}else{
obj.addEventListener(eventName,fn,false);
}
}

使用封装函数:

addEvent(obj,"click",clicnFn1);
addEvent(obj,"click",clicnFn1);

Note:在标准浏览器和ie低版本浏览器,绑定多个函数的执行顺序有所不同。

三 事件对象

事件对象是一座宝藏,里面藏着用来描述事件的信息。

例如可以在事件对象中获得,事件类型,鼠标在页面的点击的位置,点击的目标。。。等等

在标准浏览器(FF,chrome,ie9+)获取事件对象

事件对象作为事件处理函数的第一个参数(包括chrome浏览器)

function clicnFn1(ev){alert(ev);}
oBtn.onclick = clicnFn1;

Note: ev是定义的参数名,这个名字可以随便设置,比如为a,b,c..。都可以。

在ie低版本浏览器(ie6/7/8)获取事件对象(包括chrome浏览器)

事件对象会保存在全局对象window的一个属性中,属性名为event。

简单测试下:

<script>
alert(event);
</script>

在ie低版本浏览器弹出null,在chrome中弹出undefined,说明这个event已经定义

只是在ie低版本浏览器中相当于这样定义:var event = null;

在chrome中相当于这样定义:var event;

Note:要使用全局event事件对象,必须是在事件处理函数中才能获得。

例如:

function clicnFn1(){alert(event);}
clicnFn1()

直接调用,那么会弹出null或undefined。

因为这是直接调用函数,而不是作为事件处理函数调用。

在例如:

function clicnFn1(){alert(event);}
oBtn.onclick = clicnFn1;

作为事件处理函数调用,那么函数内用到event就是我们想要的事件对象了。

事件对象兼容性封装:

function clicnFn1(ev){
var e = ev || event;
};

事件暂时记录到这里,随后补充。。。

事件详解<一>的更多相关文章

  1. JavaScript事件详解-jQuery的事件实现(三)

    正文 本文所涉及到的jQuery版本是3.1.1,可以在压缩包中找到event模块.该篇算是阅读笔记,jQuery代码太长.... Dean Edward的addEvent.js 相对于zepto的e ...

  2. JavaScript事件详解-Zepto的事件实现(二)【新增fastclick阅读笔记】

    正文 作者打字速度实在不咋地,源码部分就用图片代替了,都是截图,本文讲解的Zepto版本是1.2.0,在该版本中的event模块与1.1.6基本一致.此文的fastclick理解上在看过博客园各个大神 ...

  3. 第三天:JS事件详解-事件流

    学习来源: F:\新建文件夹 (2)\HTML5开发\HTML5开发\04.JavaScript基础\6.JavaScript事件详解 学习内容:  1)基础概念 2)举例说明: 代码如上,如果用事件 ...

  4. JavaScript事件详解-zepto的事件实现

    zepto的event 可以结合上一篇JavaScript事件详解-原生事件基础(一)综合考虑源码暂且不表,github里还有中文网站都能下到最新版的zepto.整个event模块不长,274行,我们 ...

  5. JAVASCRIPT事件详解-------原生事件基础....

    javaScirpt事件详解-原生事件基础(一)   事件 JavaScript与HTML之间的交互是通过事件实现的.事件,就是文档或浏览器窗口中发生的一些特定的交互瞬间,通过监听特定事件的发生,你能 ...

  6. iOS中—触摸事件详解及使用

    iOS中--触摸事件详解及使用 (一)初识 要想学好触摸事件,这第一部分的基础理论是必须要学会的,希望大家可以耐心看完. 1.基本概念: 触摸事件 是iOS事件中的一种事件类型,在iOS中按照事件划分 ...

  7. js中鼠标滚轮事件详解

    js中鼠标滚轮事件详解   (以下内容部分内容参考了http://adomas.org/javascript-mouse-wheel/ ) 之前js 仿Photoshop鼠标滚轮控制输入框取值中已使用 ...

  8. JavaScript中的鼠标滚轮事件详解

    JavaScript中的鼠标滚轮事件详解/*Firefox注册事件*/ ~~~Firefox: addEventListener('DOMMouseScroll', handler, false)if ...

  9. 【转载】C# 中的委托和事件(详解:简单易懂的讲解)

    本文转载自http://www.cnblogs.com/SkySoot/archive/2012/04/05/2433639.html C# 中的委托和事件(详解) C# 中的委托和事件 委托和事件在 ...

  10. js keyup、keypress和keydown事件 详解

    js keyup.keypress和keydown事件  详解 js keyup.keypress和keydown事件都是有关于键盘的事件 当一个按键被pressed 或released在每一个现代浏 ...

随机推荐

  1. java系列--HTTP协议

    一.HTTP请求信息 请求行 请求头 空行 消息体 1.防盗链: 枚举类型: 二.中文乱码问题 1.Get提交 String username = request.getParameter(" ...

  2. linux设置好IP后,可以访问内网,不能访问外网

    1,设置网卡,ip vi /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth0 #描述网卡对应的设备别名,例如ifcfg-eth0的文件中它为et ...

  3. 10-instanceof

    在Java中可以使用instanceof关键字判断一个对象到底是不是一个类的实例 package com.example; class A{ void tell1(){ System.out.prin ...

  4. 【蓝牙数据采集模块】-01-Sensor Controller 功能介绍

    一. CC2650芯片内部的结构框图如图,内部包含: 一个Cortex-M3主控制器,用来做整个芯片的功能与任务实现 一个Cortex-M0射频控制器,用来驱动RF相关电路 一个Sensor Cont ...

  5. Memcached操作以及用法

    Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached ...

  6. PHP文件上传和文件操作案例

    <?php /* *文件配置变量$dirname是目录名称 */ session_start(); $dirname = 'upload'; $fileClass = new fileClass ...

  7. Angular - - $compile编译服务与指令

    $compile 这是个编译服务.编译一段HTML字符串或者DOM的模板, 产生一个将scope和模板连接到一起的函数. 编译服务主要是为指令编译DOM元素,下面的一大段也是主要介绍指令的. 下面是一 ...

  8. 让php Session 存入 redis 配置方法

    首先要做的就是安装redis 安装方法:http://redis.io/download Installation Download, extract and compile Redis with: ...

  9. web前端性能调优(二)

    项目经过第一波优化之后APP端已基本已经符合我们的要求了,但是TV端还是反应比较慢,页面加载和渲染都比较慢了一点,我觉的还是有必要在进行一些优化,经过前面的优化,我们的优化空间已经小了一部分,不过还是 ...

  10. OGG学习笔记03-单向复制简单故障处理

    OGG学习笔记03-单向复制简单故障处理 环境:参考:OGG学习笔记02-单向复制配置实例 实验目的:了解OGG简单故障的基本处理思路. 1. 故障现象 故障现象:启动OGG源端的extract进程, ...