javascript事件之:谈谈自定义事件(转)

  http://www.cnblogs.com/pfzeng/p/4162951.html

  对于JavaScript自定义事件,印象最深刻的是用jQuery在做图片懒加载的时候。给需要懒加载的图片定义一个appear事件。当页面图片开始出现时候,触发这个自定义的appear事件(注意,这里只触发一次)。

  由此,现在我们通过JavaScript谈一谈自定义事件。

  所谓事件,说的明白点,就是在一个合适的时候触发调用某个函数。平常说的事件是那些比较常用的,绑定在元素身上的某个方法,当用户触发某个行为时,(click, focus, mouseover, mouseout, load ......)这个函数触发。自定义事件也是如此,只是触发的方式可以由你自己决定,比如我们上面提到的appear事件,当这个元素可见时,触发某个自定义的方法。

  我们用JavaScript模拟一下。

//定义两个方法,为元素添加事件,触发事件 1 function add(el, type, fn){
 2     el.listeners = el.listeners || {}
 3     el.listeners[type] = el.listeners[type] || []
 4     el.listeners[type].push(fn)
 5
 6     el.addEventListener(type, fn, false);
 7 }
 8
 9 function trigger(el, type){
10     if(el.listeners){
11         var triggerArr = el.listeners[type] || [];
12         if(triggerArr.length){
13             for(var i = 0; i<triggerArr.length; i++){
14                 triggerArr[i]();
15             }
16         }
17     }
18 }

绑定事件,并触发

 1 function doFn(){
 2     alert("appear触发弹出!")
 3 }
 4 function doFn2(){
 5     alert("appear触发弹出2!")
 6 }
 7
 8 add($doTrigger, "doTrigger", doFn)
 9 add($doTrigger, "doTrigger", doFn2)
10 trigger($doTrigger, "doTrigger")

页面加载,弹出,"appear触发弹出!","appear触发弹出2!"。

实现原理非常简单。为元素添加一个属性listeners,默认为{}, 添加时候,往对象里加一个默认值为[]的type属性。触发的时候直接得到el.listeners[type]。触发里面每一个方法即可。

删除更简单

 function remove(el, type, fn){
     if(el.listeners && el.listeners[type]){
         delete el.listeners[type]
     }
     el.removeEventListener(type, fn, false)
 }

对于默认事件呢,我们也测试一下

add($clickTrigger, "click", clickFn)
add($clickTrigger, "click", clickFn1)trigger($clickTrigger, "click")
function clickFn(){
    alert("click触发弹出!")
}
function clickFn1(){
    alert("click触发弹出!")
}

页面一加载弹出。点击“click事件”也弹出。

remove($clickTrigger, "click", clickFn)
remove($clickTrigger, "click", clickFn1)

remove之后,页面加载不弹出,点击也不弹出。

注意,以上的代码都是基于w3c标注。以后有时间我们谈谈事件的兼容性。

http://www.zhangxinxu.com/wordpress/2012/04/js-dom%E8%87%AA%E5%AE%9A%E4%B9%89%E4%BA%8B%E4%BB%B6/

时间: 2024-10-29 19:12:31

javascript事件之:谈谈自定义事件(转)的相关文章

javascript和jquey的自定义事件小结

“通过事件机制,可以将类设计为独立的模块,通过事件对外通信,提高了程序的开发效率.” 可以把多个关联但逻辑复杂的操作利用自定义事件的机制灵活地控制好 对象之间通过直接方法调用来交互 1)对象A直接调用对象B的某个方法,实现交互:直接方法调用本质上也是属于一种特殊的发送与接受消息,它把发送消息和接收消息合并为一个动作完成: 方法调用方和被调用方被紧密耦合在一起:因为发送消息和接收消息是在一个动作内完成,所以无法做到消息的异步发送和接收: 2)对象A生成消息->将消息通知给一个事件消息处理器(Obs

浏览器事件机制与自定义事件的实现

一. 0 级 DOM 上的事件和 2 级 DOM 事件机制 0 级 DOM 上的事件又称原始事件模型,所有的浏览器都支持他,而且是通用的. 2 级 DOM 事件机制又为标准事件模型,除了 ie 其他浏览器都支持( ie9 据说也支持,有待考证), ie 虽然大部分与标准事件模型一样,但有自己专有的事件模型,因此开发人员要实现标准事件模型必须为 IE 写特定的代码,这给程序员增加了负担. 原始事件模型 1.<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0

Flex事件机制学习-自定义事件实现类间通信 .

今天,学习Flex自定义事件,可以使两个类通信,定义一个Main类. public class Main extends Sprite     {            public function Main()            { //演示ChildSprite类是与Main类通信,ChildSprite类稍后说明: var child:ChildSprite=new ChildSprite(); //指示该实例的属性值            child.flag="01";

js事件模型与自定义事件

JavaScript 一个最简单的事件模型,需要有事件绑定与触发,也许还要有事件删除. 1 var eventModel = { 2 list: {}, 3 4 bind: function () { 5 var args = [].slice.apply(arguments), 6 type = args[0], 7 handlers = args.slice(1); 8 9 if (typeof type === 'string' && handlers.length > 0)

通过c# 实现自定义属性改变触发自定义事件 ,理解自定义事件及其触发过程

以下说明可解释自定义的事件的自定义触发过程: 直接上代码,内含说明(界面是两个文本框textbox1,textbox2,和一个button1,界面的Load事件,button的click事件) Form1 类(调用者端) using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; us

JS过渡结束监听事件及使用自定义事件解决兼容问题的方法

1.JS过渡结束监听事件 2.自定义事件解决兼容问题 原文地址:https://www.cnblogs.com/liu-web-bew/p/9345478.html

mui 事件管理及自定义事件详解

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" /> <title></title

JavaScript 自定义事件

Javascript事件模型系列(四)我所理解的javascript自定义事件 漫谈js自定义事件.DOM/伪DOM自定义事件

详解javascript实现自定义事件

这篇文章主要为大家介绍了javascript实现自定义事件的方法,自定义事件,顾名思义,就是自己定义事件类型,自己定义事件处理函数,javascript如何实现自定义事件,需要了解的朋友可以参考下 我们平时在操作dom时候经常会用到onclick,onmouseover等一系列浏览器特定行为的事件, 那么自定义事件,顾名思义,就是自己定义事件类型,自己定义事件处理函数,在合适的时候需要哪个事件类型,就去调用哪个处理程序 1.js所支持的浏览器默认事件 浏览器特定行为的事件,或者叫系统事件,js默