事件中的几种实现方式

Dom0时代

1、直接在html的属性中写JS代码

 <div onclick="alert(4);">Div1 Element</div>

2、定义一个函数,赋值给html元素的onXXX属性

 <div onclick="clk()">Div Element</div>
<script type="text/javascript">
function clk(){
//....
}
</script>

3、使用element.onXXX方式

 <div id="d3">Div Element</div>
<script type="text/javascript">
var d3 = document.getElementById('d3');
d3.onclick = function(){
//...
}
</script>

Dom2时代

4、添加事件方式,使用addEventListener或IE专有的attachEvent

事件流

官方的定义:事件按照从最特定的事件目标到最不特定的事件目标(document对象或者body)的顺序触发。

也可说,从页面中接收事件的顺序。也就是说当一个事件产生时,这个事件的传播过程,就是事件流。

事件不是单一的,比如:点击某个按钮,其实也点击了包含按钮的DIV、文档bod、document.

 <body onclick="alert(3)">
<div onclick="alert(2)">
<button onclick="alert(1)">测试按钮</button>
</div>
</body>

在IE中,冒泡,会按这个顺序输出:1,2,3;

但在Netscape Navigator 4.0中则是‘反的’,它所支持的是捕获:输出3,2,1;

而DOM标准中事件流将这两种方式结合

window -> document -> body -> div -> button -> button -> div -> body -> document -> window;

这某些情况下,我们可能就需要去阻止事件流的传播:

 function stopEvent (evt) {
var e = (evt != null) ? evt : window.event;
if (window.event) {
e.cancelBubble=true; // ie
} else {
e.stopPropagation(); // 标准组织
}
}

绑定、解绑、参数、事件对象在IE与W3C中的区别

 Evt.extend({
// 添加事件
on : function(ele,type, fn){
if(document.addEventListener){
ele.addEventListener(type, fn, false);
}else if(document.attachEvent){
ele.attachEvent('on' + type, fn);
}else{
ele['on' + type] = fn;
}
},
// 解除事件
un : function(ele,type, fn){
if(document.removeEventListener){
ele.removeEventListener(type, fn);
}else if(document.detachEvent){
ele.detachEvent(type, fn);
}else{
ele['on' + type] = null;
}
},
/*点击*/
click : function(ele,fn){
this.on(ele,'click',fn);
},
// ...
});

Event接口(IE低版本浏览器不做专门的讨论)

    JS里并没有严格的接口概念,只是为程序提供了某个对象拥有某些属性或者方法的描述

Event对象实现Event接口或子接口,声明了该种事件类型的详细信息。

其中Event是基础接口,UIEvent 和 MutationEvent是他的子接口。而MouseEvent又是UIEvent的子接口

  Event 接口具有如下属性和方法

Type                     指明事件的类型

Target                  发生事件的节点      // srcElement

currentTarget        事件当前传播到达的节点。

eventPhase            当前所处的事件传播阶段(捕获、目标、冒泡)

timeStamp            事件发生的时间点(时间戳)

cancelable              声明事件是否取消默认动作

bubbles                 声明事件时候在文档中起泡

stopPorpagation()   阻止冒泡     // cancelBubble

preventDefault       阻止默认动作的执行

...

  UIEvent接口属性

Event的子接口,在其基础上定义了两个新的属性:

view   发生事件的window对象

detail    提供事件的额外信息

MouseEvent 接口属性

是UIEvent的子接口,在UIEvent基础上定义了下列属性

button                                          mousedown  click 等事件中,鼠标键的状态(0鼠标左键2鼠标右键)

altKey ctrlKey metaKay shiftKey      在鼠标事件发生时。是否按下了该键

clientX \Y                                      事件发生时,鼠标指针相对于浏览器左上角的坐标

screenX\Y                                      相对于显示器左上角的坐标

...

事件的代理与委托

通过事件的冒泡机制来实现的

优点:

1、是可以节省大量的内存占用,减少事件注册,比如在table上可以代理所有td的click事件

2、对新增的子对象不需要再次绑定事件,适于动态内容部分

缺点:

不能所有的事件都用代理,不应该触发的元素也被绑上了事件。

 function delegate(pid, eventType, selector, fn) {
var parent = $$.$id(pid);
function handle(e){
var target = $$.GetTarget(e);
console.log(target.nodeName)
if(target.nodeName.toLowerCase()=== selector || target.id === selector || target.className.indexOf(selector) != -1){
fn.call(target);
}
}
parent[eventType]=handle;
}
delegate('table','onclick','td',function(){
this.style.color='white'
this.style.background='red'
})

 自定义事件

  //将有参数的函数封装为无参数的函数
function createFunction(obj, strFunc) {
var args = []; //定义args 用于存储传递给事件处理程序的参数
if (!obj) obj = window; //如果是全局函数则obj=window;
//得到传递给事件处理程序的参数
for (var i = 2; i < arguments.length; i++){
// alert(arguments[i]);
args.push(arguments[i]);
}
//用无参数函数封装事件处理程序的调用
return function() {
obj[strFunc].apply(obj, args); //将参数传递给指定的事件处理程序
}
}
function class1() {
}
class1.prototype = {
show: function() {
this.onShow();
},
onShow: function() { }
}
function objOnShow(userName) {
alert("hello," + userName);
}
function test() {
var obj = new class1();
var userName = "test";
obj.onShow = createFunction(null, "objOnShow", userName);
console.log(obj.onShow)
obj.show();
}
test()

JS中的事件的更多相关文章

  1. 怎么理解js中的事件委托

    怎么理解js中的事件委托 时间 2015-01-15 00:59:59  SegmentFault 原文  http://segmentfault.com/blog/sunchengli/119000 ...

  2. js中冒泡事件和捕获事件

    js中冒泡事件和捕获事件: 冒泡事件:冒泡事件是从里向外,即是从被绑定元素开始一直向外到达页面的所有祖先元素都会被触发,这 一过程被称为事件冒泡.这个事件从原始元素开始一直冒泡到DOM树的最上层 捕获 ...

  3. 看懂此文,不再困惑于 JS 中的事件设计

    看懂此文,不再困惑于 JS 中的事件设计 今天刚在关注的微信公众号看到的文章,关于JS事件的,写的很详细也很容易理解,相关的知识点都有总结到,看完就有种很舒畅的感觉,该串起来的知识点都串起来了.反正一 ...

  4. js中冒泡事件

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. DOM 以及JS中的事件

    [DOM树节点] DOM节点分为三大节点:元素节点,文本节点,属性节点. 文本节点,属性节点为元素节点的两个子节点通过getElment系列方法,可以去到元素节点 [查看节点] 1 document. ...

  6. 从零开始的JS生活(二)——BOM、DOM与JS中的事件

    上回书说道,JS中变量.运算符.分支结构.循环和嵌套循环等内容.本回就由本K给大伙唠唠JS中的BOM.DOM和事件. 一."花心大萝卜"--BOM 1.震惊,FFF团为何对BOM举 ...

  7. js中的事件,内置对象,正则表达式

    [JS中的事件分类] 1.鼠标事件: click/dbclick/mouseover/mouseout/mousemove/mousedown/mouseup 2.键盘事件: keydown: 键盘按 ...

  8. JS中的事件以及DOM 操作

    [DOM树节点] DOM节点分为三大节点:元素节点,文本节点,属性节点. 文本节点,属性节点为元素节点的两个子节点通过getElment系列方法,可以去到元素节点 [查看节点] 1 document. ...

  9. JS中的事件&对象

    一.JS中的事件 (一)JS中的事件分类 1.鼠标事件 click/dblclick/onmouseover/onmouseout 2.HTML事件 onload/onscroll/onsubmit/ ...

  10. JS学习五(js中的事件)

    [JS中的事件分类] 1.鼠标事件 click/bdlclick/onmouseover/onmouseout 2. HTML事件 onload/onscroll/onsubmit/onchange/ ...

随机推荐

  1. 做贴吧系统,偶然发现使用iframe的弊端

    个人拙见 常听人说起现在不建议使用iframe框架,而我却一再使用,也许是能力有限,一直没在意有什么弊端. 我这此使用的事左右iframe框架,并且只在主页中定义了大背景,每个页面并没有分别定义背景, ...

  2. Windows 7专业版安装VS2005与WinCE6.0开发环境

    近期更新了自己的小黑从XP更新到WIN7专业版,我花了两天时间验证了下列软件安装在WIN7 PRO是完全兼容的. 1:2011年最新更新的SourceInsight3.50.0066版本,这个是支持W ...

  3. ab网站压力测试

    ab网站压力测试命令的参数.输出结果的中文注解    permalink 以前安装好APACHE总是不知道该如何测试APACHE的性能,现在总算找到一个测试工具了.就是APACHE自带的测试工具AB( ...

  4. iTextSharp快速使用指南

    前言 最近公司一直使用iText开发PDF报表,使用一段时间之后发现iText这个类库虽然是庞大无比,但作为程序猿我们不需要知道所有的类和方法,我们只需要知道如何使用即可. 所以这篇文章就是告诉大家如 ...

  5. 百度云推送-服务端 C# SDK

    思路: 1.公司有项目需要做android和ios手机端推送消息的功能: 2.没有接触过这方面的知识,一头雾水,开始在网上一顿搜,网上倒是有不少解决方案,首先搜的是android的解决方案,因为ios ...

  6. 孙鑫MFC学习笔记13:文档

    1.CArchive类保存内存数据 2.CAchive类重载了>>与<<操作符,类似C++文件流 3.在OnNewDocument中通过SetTitle设置标题 4.字符串资源 ...

  7. int和Integer的区别

    int是一种数据类型,Integer是一个类,有各种方法,如Integer.parseInt(string)等.

  8. Android存储空间不足的解决办法

    安装应用时,有时会出现错误Installation error: INSTALL_FAILED_INSUFFICIENT_STORAGE,这是存储空间不足的错误,这时就只能将应用安装到SD卡,在And ...

  9. How do you install mysql-connector-python (development version) through pip?

    12down votefavorite 8 http://stackoverflow.com/questions/31748278/how-do-you-install-mysql-connector ...

  10. SSH中的jar包讲解(1)

    我们在搭建SSH框架的时候,需要引入各自的一些jar包,相信很多初学者跟我一样,搜个资料,照搬过来(当然版本还得对应),至于为什么要引入这些个jar包,引入它们的作用是啥子,一头雾水,今天我就来跟这些 ...