• javaScript事件(三)事件对象


    一、事件

    二、事件流

    以上内容见:javaScript事件(一)事件流

    三、事件处理程序

    四、IE事件处理程序

    以上内容见javaScript事件(二)事件处理程序

    五、事件对象

    什么是事件对象?在触发DOM上的事件时都会产生一个对象。

    1、认识事件对象

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

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

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

    2、html事件处理程序中event

    <input id="btn" type="button" value="click" onclick=" console.log('html事件处理程序'+event.type)"/>

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

    3、DOM中的事件对象

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

    根据习惯来:可以用e,或者ev或者event。

    <body>
    <input id="btn" type="button" value="click"/>
    <script>
        var btn=document.getElementById("btn");
        btn.onclick=function(event){
            console.log("DOM0 & click");
            console.log(event.type);    //click
        }
        btn.addEventListener("click", function (event) {
            console.log("DOM2 & click");
            console.log(event.type);    //click
        },false);
    </script>
    </body>

    DOM中事件对象重要属性和方法。总结:【update 20170313】

    属性

    • type属性,用于获取事件类型
    • target属性 用户获取事件目标 事件加在哪个元素上。(更具体target.nodeName)

    方法

    • stopPropagation()方法 用于阻止事件冒泡
    • preventDefault()方法 阻止事件的默认行为 移动端用的多

    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>

     IE中事件对象重要属性和方法。总结:【update 20170313】

    属性:

    • type属性,用于获取事件类型(一样)
    • srcElement属性 用户获取事件目标 事件加在哪个元素上。(更具体target.nodeName)
    //兼容性处理
    function showMsg(event){
        event=event||window.event;  //IE8以前必须是通过window获取event,DOM中就是个简单的传参
        var ele=event.target || event.srcElement; //获取目标元素,DOM中用target,IE中用srcElement
        alert(ele);
     }
    • cancelBubble属性 用于阻止事件冒泡 IE中cancelBubble为属性而不是方法,true表示阻止冒泡。
    • returnValue属性 阻止事件的默认行为 false表示阻止事件的默认行为

    但是我有两个地方不懂。

    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>

    六、事件对象的公共成员

    这部分内容见javaScript事件(四)event的公共成员(属性和方法)

    七、鼠标事件

    这部分内容见javaScript事件(五)事件类型之鼠标事件

     

    本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/4077532.html有问题欢迎与我讨论,共同进步。

  • 相关阅读:
    echarts 折线图(移动端)X轴显示不全
    文字超出省略号类型
    逻辑运算为true
    13年省赛总结
    PyCharm专业版破解教程
    django之定义统一返回数据格式与GET/POST装饰器
    Xmind8破解教程
    django之mysqlclient安装
    django之“static”全局设置
    django之集成第三方支付平台PaysAPI与百度云视频点播服务接入
  • 原文地址:https://www.cnblogs.com/starof/p/4077532.html
Copyright © 2020-2023  润新知