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。

<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>

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

属性

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

方法

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

4、IE中的事件对象

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

<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>

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

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

 IE中事件对象重要属性和方法

属性:

  • 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表示阻止事件的默认行为

六、事件对象的公共成员

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

七、鼠标事件

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

 

猜你喜欢

转载自blog.csdn.net/u013987258/article/details/81144796