首先是一个小例子:

<input type="text" onclick="a(event)"/>

function a(event){
   console.log(event)
}

event对象代表事件的状态,包括事件在其中发生的元素,键盘按键的状态、鼠标的位置、鼠标按键的状态

有MouseEvent(click,mouseover...),FocusEvent(focus)等

这里输出MouseEvent{}, 包含以下属性:

  1. altKey: false
  2. bubbles: true
  3. button: 0
  4. buttons: 0
  5. cancelBubble: false
  6. cancelable: true
  7. charCode: 0
  8. clientX: 79
  9. clientY: 24
  10. ctrlKey: false
  11. currentTarget: null
  12. dataTransfer: null
  13. defaultPrevented: false
  14. detail: 0
  15. eventPhase: 0
  16. fromElement: null
  17. keyCode: 0
  18. layerX: 79
  19. layerY: 24
  20. metaKey: false
  21. movementX: 0
  22. movementY: 0
  23. offsetX: 71
  24. offsetY: 13
  25. pageX: 79
  26. pageY: 24
  27. path: Array[5]
  28. relatedTarget: null
  29. returnValue: true
  30. screenX: 105
  31. screenY: 179
  32. shiftKey: false
  33. srcElement: input
  34. target: input
  35. timeStamp: 1477020320584
  36. toElement: input
  37. type: "mouseover"
  38. view: Window
  39. webkitMovementX: 0
  40. webkitMovementY: 0
  41. which: 0
  42. x: 79
  43. y: 24

详情: http://zccst.iteye.com/blog/1806261

详解:

鼠标/键盘属性:

altKey   事件发生时,alt键有没有被按下(布尔)

ctrlKey 事件发生时,ctrl键有没有被按下(布尔)

shiftKey 事件发生时,shift键有没有被按下(布尔)

metaKey 事件发生时,meta键有没有被按下(布尔)在windows下meta是那个飘小旗的键 在苹果系统中就是Cmd键

button  事件发生时,鼠标哪一个按键被点击(左键0/右键1)

relatedTarget 与事件发生的目标节点相关的节点(没有为null)

-----------------------------------------------------------------------------------------------------------------------------

各种定位:

clientX 事件发生时,鼠标水平坐标(数字)

clientY 事件发生时,鼠标垂直坐标(数字)

兼容性 全部

参照点为当前浏览器内容区域的左上角,随着滚动条的移动,参照点会改变

screenX screenY 与clientX类似,返回数字

参照点为电脑屏幕而非浏览器

兼容性 全部

pageX pageY

参照点为浏览器内容区域的左上角,不随滚动条的移动而改变

兼容性 chrome firefox opera IE9+

offsetX offsetY

参照点为该元素内容的的左上角,如果有border,可能出现负值

兼容性 chrome opera safari IE6+(原IE独有)

layoutX layoutY

参照点为1.若触发元素为绝对定位或相对定位,则以触发元素的border为参照物(类似offsetX,不过以border为参照物,不会有负值!)

    2.若不是,以页面为参照物

    3.IE为相对当前坐标系的border左上角开始的坐标 + 滚动条滚过的距离

兼容性 chrome firefox safari IE9+(原firefox独有)

x y

原IE独有,部分浏览器支持,不过能不用就不用!

具体可参考:

http://blog.sina.com.cn/s/blog_780a94270101kdgo.html

http://shanmao.me/web/js/pagex-clientx-offsetx-layerx-de-qu-bie

这些属性只有chrome和safari全部支持,但只有screenX和clientX符合w3c标准!

------------------------------------------------------------------------------------------------------------标准event属性:

bubbles 时间是否为起泡事件(布尔)

cancelable 事件是否有可取消的默认动作

currentTarget 触发该事件的元素(该元素或其子元素)

target 目标节点

timeStamp 事件生成的时间(毫秒数)

type 事件名称(比如 "click", "mouseover")

eventPhase 事件传播的当前阶段(捕获阶段1 正常事件派发2 起泡阶段3)

--------------------------------------------------------------------------------------------------------------------------------

标准event方法:

initEvent() 初始化新创建的Event对象的属性

preventDefault 阻止默认动作

stopPropagation 不再派发事件

---------------------------------------------------------------------------------------------------------------------------------

IE属性:

cancelBubble 阻止事件传播到包容对象(布尔值) 类似于stopPropagation ()

returnValue 取消默认动作 类似于preventDefault()

srcElement 生成事件的window对象,document对象或element对象 类似于target()

余下IE属性局限性大,不再解释,详情请看链接页面

--------------------------------------------------------------------------------------------------------

兼容性写法:

1.event

event || (event= window.event)

eg: function a(event){

  event || (event= window.event);

}

2.target

var target= event.target || event.srcElement;

3.preventDefault()

event.preventDefault? event.preventDefault(): (event.returnValue= false);

4.stopPropagation()

event.stopPropagation? event.stopPropagation(): (event.cancelBubble= true);

event小解的更多相关文章

  1. 如何利用ETW(Event Tracing for Windows)记录日志

    ETW是Event Tracing for Windows的简称,它是Windows提供的原生的事件跟踪日志系统.由于采用内核(Kernel)层面的缓冲和日志记录机制,所以ETW提供了一种非常高效的事 ...

  2. [.NET] C# 知识回顾 - Event 事件

    C# 知识回顾 - Event 事件 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/6060297.html 序 昨天,通过<C# 知识回顾 - ...

  3. Atitit 解决Unhandled event loop exception错误的办法

    Atitit 解决Unhandled event loop exception错误的办法 查看workspace/.metadata/.log org.eclipse.swt.SWTError: No ...

  4. Java模拟Windows的Event

    场景 开发中遇到一个场景,业务操作会不定时的产生工作任务,这些工作任务需要放入到一个队列中,而另外会有一个线程一直检测这个队列,队列中有任务就从队列中取出并进行运算. 问题 业务场景倒是简单,只不过这 ...

  5. 事件EVENT与waitforsingleobject的使用

    事件event与waitforsingleobject的配合使用,能够解决很多同步问题,也可以在数据达到某个状态时启动另一个线程的执行,如报警. event的几个函数: 1.CreateEvent和O ...

  6. 火狐浏览器中event不起作用解决办法--记录(一)

    今天遇到了这个问题.IE,谷歌下都没问题,但在FF下却不起作用,很郁闷查了半天,看别人博文写了老长,结果试了要么起作用,但太麻烦,要么不起作用,说了那么多跟没说一样. 其实只要这一句代码就行:e=ar ...

  7. Event事件

    妙味课堂-Event事件 1.焦点:当一个元素有焦点的时候,那么他就可以接受用户的输入(不是所有元素都能接受焦点) 给元素设置焦点的方式: 1.点击 2.tab 3.js 2.(例子:输入框提示文字) ...

  8. Event Sourcing Pattern 事件源模式

    Use an append-only store to record the full series of events that describe actions taken on data in ...

  9. 严重: Exception sending context initialized event to listener instance of class

    问题描述:Exception sending context initialized event to listener instance of class org.springframework.w ...

随机推荐

  1. js--局部变量

    今天公司一个实习小妹子问我两段JS代码的区别: <script type="text/javascript"> var a = "Hello"; f ...

  2. Dokan简介[转]

    1.      Dokan Library 简介 Dokan Library 帮助程序员在windows系统下轻松建立用户级文件系统,不需要写设备驱动,其与FUSE(Linux user mode f ...

  3. 利用scrollTop 制作图片无缝滚动

    <!doctype html><title>javascript无缝滚动 by 司徒正美</title><meta charset="utf-8&q ...

  4. javascript注释规范

    注释在代码编写过程中的重要性,写代码超过半年的就能深深的体会到.没有注释的代码都不是好代码.为了别人学习,同时为了自己以后对代码进行'升级',看看js/javascript代码注释规范与示例.来自:h ...

  5. 用非GUI模式执行测试,jp@gc - PerfMon Metrics Collector会出现无法获取正确数据的解决办法

    用非GUI模式执行测试,jp@gc - PerfMon Metrics Collector会出现无法获取正确数据(实际显示的是Response Times Over Time),解决办法:在GUI模式 ...

  6. 【第三篇】学习 android 事件总线androidEventbus之发布事件,子线程中接收

    发送和接收消息的方式类似其他的发送和接收消息的事件总线一样,不同的点或者应该注意的地方: 1,比如在子线程构造方法里面进行实现总线的注册操作: 2,要想子线程中接收消息的功能执行,必须启动线程. 3, ...

  7. 【第三篇】学习 android 事件总线androidEventbus之list数据事件的传递,发送list数据事件到另外一个Activity

    这个和普通的事件总线的发送接收一样. package com.example.mysimpleeventbus; import java.util.ArrayList; import java.uti ...

  8. HDU 5769 Substring

    后缀数组. 然后按照排序完成之后的顺序,每个后缀统计贡献量. 统计第i个后缀的贡献的时候,如果这个后缀中没有X,贡献度为0. 有贡献的分3种情况考虑: 1.如果这个后缀height部分等于0(即与前一 ...

  9. div+css位置绝对定位和相对定位

    position:absolute: 当div中被隔着些元素的话那么用此方法将把元素重叠在一起,所以元素可以不在容器中加也能重叠在一起

  10. Entity Framework技巧系列之五 - Tip 16 – 19

    提示16. 当前如何模拟.NET 4.0的ObjectSet<T> 背景: 当前要成为一名EF的高级用户,你确实需要熟悉EntitySet.例如,你需要理解EntitySet以便使用 At ...