[JS学习笔记]浅谈Javascript事件模型

DOM0级事件模型

element.on[type] = function(){}

兼容性:全部支持

lay1

lay2

lay3

  • e.target:直接触发事件的元素[IE8及以下不支持taget属性,使用e.srcElement代替]
  • e.srcElement:直接触发事件的元素[FF不支持srcElement属性,使用e.target代替]
  • e.currentTarget:被间接触发的元素[IE8及以下不支持currentTarget属性,使用this代替]
  • this:同e.currentTarget[所有浏览器通用]

DOM2级事件模型

attachEvent

兼容性:IE5-IE10支持,IE11不支持,ff不支持

lay1

lay2

lay3

  • 对于支持的浏览器
  • e.target:不支持该属性
  • e.srcElement:直接触发事件的元素
  • e.currentTarget:不支持该属性
  • this:始终指向window,可以使用call/apply改变this指向
    element.attachEvent("on"+type,function(){ handler.apply(element,arguments); })

DOM2级事件模型

addEventListener

兼容性:IE5-IE8不支持,IE9-IE11支持,ff支持

lay1

lay2

lay3

  • 对于支持的浏览器
  • e.target:直接触发事件的元素
  • e.srcElement:不支持该属性
  • e.currentTarget:被间接触发的元素
  • this:同e.currentTarget
$(function() {

            //dom0级事件绑定
            var eleArr_d1 = $.makeArray($(".demo1").find(".layer1,.layer2,.layer3"));
            $.each(eleArr_d1, function (i, o) {
                o.onclick = fn0;
            });

            function fn0(e) {
                e = e || window.event;
                console.log("e.target=", getName(e.target));
                console.log("e.srcElement=", getName(e.srcElement));
                console.log("e.currentTarget=", getName(e.currentTarget));
                console.log("this=", getName(this));
                console.log("========================================================");
            }

            //dom2级事件绑定[IE]
            var eleArr_d2 = $.makeArray($(".demo2").find(".layer1,.layer2,.layer3"));
            if (document.attachEvent) {
                $.each(eleArr_d2, function(i, o) {
                    o.attachEvent("onclick", function() { fn2_ie.apply(o,arguments); });//改变this指向
                });
            } else {
                $(".demo2").find(".error").text("当前浏览器不支持attachEvent").show().css({ display: "inline-block" });
            }

            function fn2_ie(e) {
                e = e || window.event;
                console.log("e.target=", getName(e.target));
                console.log("e.srcElement=", getName(e.srcElement));
                console.log("e.currentTarget=", getName(e.currentTarget));
                console.log("this=", getName(this));
                console.log("========================================================");
            }

            //dom2级事件绑定[FF]
            var eleArr_d3 = $.makeArray($(".demo3").find(".layer1,.layer2,.layer3"));
            if (document.addEventListener) {
                $.each(eleArr_d3, function(i, o) {
                    if (o.addEventListener) o.addEventListener("click", fn3_ff, false);
                });
            } else {
                $(".demo3").find(".error").text("当前浏览器不支持addEventListener").css({display:"inline-block"});
            }

            function fn3_ff(e) {
                e = e || window.event;
                console.log("e.target=", getName(e.target));
                console.log("e.srcElement=", getName(e.srcElement));
                console.log("e.currentTarget=", getName(e.currentTarget));
                console.log("this=", getName(this));
                console.log("========================================================");
            }

            function getName(ele) {
                if (ele==null) {
                    return ele;
                }else if (ele.className) {
                    return ele.className;
                } else if (ele.tagName) {
                    return ele.tagName;
                }else if (ele.nodeName) {
                    return ele.nodeName;
                } else {
                    return ele;
                }
            }

        })
时间: 2024-11-07 19:39:49

[JS学习笔记]浅谈Javascript事件模型的相关文章

浅谈Javascript事件模拟

事件是用来描述网页中某一特定有趣时刻的,众所周知事件通常是在由用户和浏览器进行交互时触发,其实不然,通过Javascript可以在任何时间触发特定的事件,并且这些事件与浏览器创建的事件是相同的.这就意味着会有适当的事件冒泡,并且浏览器会执行分配的事件处理程序.这种能力在测试web应用程序的时候,是非常有用的,在DOM 3级规范中提供了方法来模拟特定的事件,IE9 chrome FF Opera 和 Safari都支持这样的方式,在IE8及以前的办法的IE浏览器有他自己的方式来模拟事件a)Dom

Java学习笔记——浅谈数据结构与Java集合框架(第一篇、List)

横看成岭侧成峰,远近高低各不同.不识庐山真面目,只缘身在此山中. --苏轼 这一块儿学的是云里雾里,咱们先从简单的入手.逐渐的拨开迷雾见太阳.本次先做List集合的三个实现类的学习笔记 List特点:有序,元素可重复.其实它的本质就是一个线性表(下面会说到) 先上图,Java集合有Collection体系和Map体系: 然后简单介绍一下数据结构和算法: 数据结构就是数据和数据之间的关系,好比分子结构,晶体结构.碳原子按照一定的方式组合在一起形成碳分子,碳分子再按照一定方式形成晶体. 算法是对解题

JS学习笔记9之event事件及其他事件

-->鼠标事件-->event事件对象-->默认事件-->键盘事件(keyCode)-->拖拽效果 一.鼠标事件 onclick ---------------鼠标点击事件oncontextmenu------鼠标右键点击onmouseover --------鼠标移上onmouseout ---------鼠标移出onmousedown -------鼠标按下onmousemove -------鼠标移动onmouseup ----------鼠标抬起 1 <head

Java学习笔记——浅谈数据结构与Java集合框架(第二篇、Queue、Set)

江南好,何处异京华. 香散翠帘多在水,绿残红叶胜于花.无事避风沙. --<纳兰词> 诗词再好,大图不能忘 上大图: 先说说栈和队列: 栈就好比手枪的弹匣,你往里面压入子弹,最先压入的子弹就到了弹匣最底部的位置,最后压入的子弹在弹匣顶部.发射子弹的时候每次将弹匣顶部的子弹弹出发射.无法越过顶部子弹发射下面的子弹. 栈(stack)是限定仅在表尾进行插入和删除操作的线性表,LIFO 队列就跟上学那会儿排队打饭一样,但是不能加塞儿. 队列(queue)是只允许在队列一端进行插入操作,另一端进行删除操

《浅谈JavaScript系列》系列技术文章整理收藏

<浅谈JavaScript系列>系列技术文章整理收藏 1浅谈JavaScript中面向对象技术的模拟 2浅谈javascript函数劫持[转自xfocus]第1/3页 3浅谈javascript 面向对象编程 4老鱼 浅谈javascript面向对象编程 5浅谈javascript的数据类型检测 6浅谈Javascript嵌套函数及闭包 7根据一段代码浅谈Javascript闭包 8浅谈JavaScript编程语言的编码规范 9浅谈Javascript面向对象编程 10浅谈JavaScript

JS学习笔记-事件绑定

一.传统事件模型 传统事件模型中存在局限性. 内联模型以HTML标签属性的形式使用,与HTML混写,这种方式无疑造成了修改以及扩展的问题,已经很少使用了. 脚本模型是将事件处理函数写到js文件中,从页面获取元素进行对应事件函数的绑定以触发执行.但也存在不足之处: 1.一个事件绑定多个事件监听函数,后者将覆盖前者. 2.需要限制重复绑定的情况 3.标准化event对象 二.现代事件绑定 DOM2级事件定义了两个方法用于添加.删除事件:addEventListener().removeEventLi

Node.js学习笔记【1】入门(服务器JS、函数式编程、阻塞与非阻塞、回调、事件、内部和外部模块)

笔记来自<Node入门>@2011 Manuel Kiessling JavaScript与Node.js Node.js事实上既是一个运行时环境,同时又是一个库. 使用Node.js时,我们不仅仅在实现一个应用,同时还实现了整个HTTP服务器. 一个基础的HTTP服务器 server.js:一个可以工作的HTTP服务器 var http = require("http"); http.createServer(function(request, response) { r

【转】Backbone.js学习笔记(二)细说MVC

文章转自: http://segmentfault.com/a/1190000002666658 对于初学backbone.js的同学可以先参考我这篇文章:Backbone.js学习笔记(一) Backbone源码结构 1: (function() { 2: Backbone.Events // 自定义事件 3: Backbone.Model // 模型构造函数和原型扩展 4: Backbone.Collection // 集合构造函数和原型扩展 5: Backbone.Router // 路由

memcached学习笔记6--浅谈memcached的机制 以及 memcached细节讨论

附:请浅谈memcached的机制 答: ①基于C/S架构,协议比较简单 c/s架构,此时memcached为服务器端,我们可以使用如PHP,c++/c等程序连接memcached服务器. memcached的服务器客户端通信并不使用XML等格式,而使用简单的基于文本行的协议,因此通过telnet也能在memcached上保存.读取数据. ②基于libevent事件来处理的 libevent是一套垮平台的事件处理接口的封装,能够处理兼容包括这些操作系统: windows/Linux/BSD/So