javascript代码实例教程-javaScript事件(三)事件对象

发布时间:2019-01-21 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了javascript代码实例教程-javaScript事件(三)事件对象脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。 1、认识事件对象

 

事件在浏览器中是以对象的形式存在的,即event。触发一个事件,就会产生一个事件对象event,该对象包含着所有与事件有关的信息。包括导致事件的元素、事件的类型以及其他与特定事件相关的信息。

 

例如:鼠标操作产生的event中会包含鼠标位置的信息;键盘操作产生的event中会包含与按下的键有关的信息。

 

所有浏览器都支持event对象,但支持方式不同,在DOM中event对象必须作为唯一的参数传给事件处理函数,在IE中event是window对象的一个属性。

 

2、htML事件处理程序中event

 

<input id="BTn" tyPE="button" value="click" onclick=" console.LOG(&#39;html事件处理程序'+event.type)"/>

这样会创建一个包含局部变量event的函数。可通过event直接访问事件对象。

 

3、DOM中的事件对象

 

DOM0级和DOM2级事件处理程序都会把event作为参数传入。

 

复制代码

<body>

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

<script>

    VAR btn=document.getElementById("btn");

    btn.onclick=function(event){

        console.log("DOM0 &amp; click");

        console.log(event.type);    //click

    }

    btn.addEventListener("click", function (event) {

        console.log("DOM2 & click");

        console.log(event.type);    //click

    },false);

</script>

</body>

复制代码

 

 

4、IE中的事件对象

 

第一种情况: 通过DOM0级方法添加事件处理程序时,event对象作为window对象的一个属性存在。

 

复制代码

<body>

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

<script>

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

    btn.onclick= function () {

        var event=window.event;

       console.log(event.type); //click

    }

</script>

</body>

复制代码

第二种情况:通过attachEvent()添加的事件处理程序,event对象作为参数传入。

 

复制代码

<body>

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

<script>

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

    btn.attachEvent("onclick", function (type) {

        console.log(event.type);    //click

    })

</script>

</body>

复制代码

 

 

但是我有两个地方不懂。

 

1、通过DOM0级方法添加的事件处理程序中同样可以传入一个event参数,它的type和window.event.type一样,但是传入的event参数却和window.event不一样,为什么?

 

    btn.onclick= function (event) {

        var event1=window.event;

        console.log('event1.type='+event1.type);  //event1.type=click

        console.log('event.type='+event.type);    //event.type=click

        console.log('event1==event?'+(event==event1));  //event1==event?false

    }

2、通过attachEvent添加的事件处理程序中传入的event和window.event是不一样的,为什么?

 

复制代码

<body>

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

<script>

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

    btn.attachEvent("onclick", function (type) {

        console.log(event.type);    //click

        console.log("event==window.event?"+(event==window.event)); //event==window.event?false

    })

</script>

</body>

觉得可用,就经常来吧! 脚本宝典 欢迎评论哦! js脚本,巧夺天工,精雕玉琢。小宝典献丑了!

脚本宝典总结

以上是脚本宝典为你收集整理的javascript代码实例教程-javaScript事件(三)事件对象全部内容,希望文章能够帮你解决javascript代码实例教程-javaScript事件(三)事件对象所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。