js event事件

转载:https://segmentfault.com/a/1190000016106775

什么是事件对象?

在触发DOM上的某个事件时,会产生一个事件对象event。这个对象包含着所有与事件有关的信息。包括导致事件的元素,事件的类型以及其他特定事件相关的信息。

比如:

鼠标操作导致的事件对象中,会包含鼠标位置的信息。

键盘操作导致的事件对象中,会包含按下键的有关信息。

下面是点击document时event包含的属性

 event对象的兼容写法

event对象不能兼容所有的浏览器,我们一般是采用下面的这种方式进行兼容。

var oEvent = ev || event;

如果参数不是ev而是event的时候,兼容方式也可以写成下面这种格式。

document.onclick=function(event){
    var oEvent = event || window.event;
    console.log(event);
}

测试代码如下:

<!DOCTYPE html>
<html>
  <head>
    <title>event兼容测试</title>
    <script>
      window.onload=function(){
        document.onclick=function(ev){
          var oEvent=ev || event;
          console.log(event);
        }
      }
    </script>
  </head>
  <body>
  </body>
</html>

event常用属性

  • oEvent.type ,获取绑定的事件类型,比如click、mouseover等;
  • oEvent.target,(在IE低版本中用event.srcElement),返回触发事件的元素。比如[object HTMLInputElement]指的是HTML里的input元素;
  • oEvent.currentTarget,(IE低版本中不存在)表示当前所绑定事件的元素。跟target的区别看下面代码。
<!DOCTYPE html>
<html>
  <head>
    <title>event.target和event.currentTarget的区别</title>
    <script>
      window.onload=function(){
        document.onclick=function(ev){
          var oEvent=ev || event;
          var oCurrentElement=oEvent.target || oEvent.srcElement;
          console.log(oCurrentElement);
          console.log(oEvent.currentTarget);
          console.log(oEvent.type);
        }
      }
    </script>
  </head>
  <body>
    <input id="btn1" type="button" value="事件处理程序">
  </body>
</html>

 

  • oEvent.stopPropagation(),(在ie中用oEvent.cancelBubble=false)//用于阻止事件冒泡
  • oEvent.stopImmediatePropagation(),//当一个元素绑定多个事件处理程序的时候,事件会按照顺序全部执行,如果不想让后面的事件处理程序执行,就在当前事件里加这个方法,就不执行后面的事件处理程序了。
  • oEvent.preventDefault();(在ie低版本中用oEvent.returnValue=true)//阻止事件的默认行为,比如阻止a的href链接。在智能设讲用return false。
<!DOCTYPE html>
<html>
  <head>
    <title>仿select下拉框、阻止默认动作、阻止默认行为</title>
    <style>
      #div1{
        width: 400px;
        height: 300px;
        background: #ccc;
        display: none;
      }
    </style>
    <script>
      window.onload=function(){
        var oBtn=document.getElementById("btn1");
        var oDiv=document.getElementById("div1");
        var oA=document.getElementById("a1");
        oBtn.onclick=function(event){
          oDiv.style.display="block";
          var oEvent=event || window.event;
          if(oEvent.stopPropagation){
            oEvent.stopPropagation();
          }else{
            oEvent.cancelBubble=true;//IE,在新版的chrome中支持
          }
        }
        oA.onclick=function(){
          var oEvent=event || window.event;
          if(oEvent.preventDefault){
            oEvent.preventDefault();
          }else{
            oEvent.returnValue=false;//IE
          }
        }
        document.onclick=function(){
          oDiv.style.display="none";
        }
      }
    </script>
  </head>
  <body>
    <input id="btn1" type="button" value="显示">
    <div id="div1"></div>
    <a href="http://www.baidu.com" id="a1">a链接</a>
  </body>
</html>
  • oEvent.clientX;鼠标的横坐标。
  • oEvent.clientY;鼠标的纵坐标。

阻止默认事件

普通事件是没有返回值的,在事件中我们可以通过return false来阻止默认事件。下面我们在右键菜单中通过return false阻止弹出右键菜单。
我们在某个动作里用return false告诉浏览器,不用你帮忙了,我们自己处理。比如下面的代码我们在oncontextmenu右键菜单事件里return false告诉浏览器,我不需要默认的菜单了,如果我们需要一个自定义菜单,我们可以return false默认菜单然后自己定义自己的菜单。

<!DOCTYPE html>
<html>
  <head>
    <title>return false取消默认行为,取消右键菜单</title>
    <script>
      window.onload=function(){
        document.oncontextmenu=function(){
          return false;//阻止默认事件
        }
      }
    </script>
  </head>
  <body>
    oncontextmenu环境菜单,上下文菜单
  </body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值