自然,我们都习惯了 IE,在 IE 中要在函数中获得各事件对象很容易,直接用 event、event.srcElemtn、event.fromElement、event.toElement 就行了。在 FireFox 中获得触发事件的元素可以用 event.target,但其他两个 fromElement 和 toElement 就要费些周折。

 

1、event.srcElement :当前事件的源

   var obj = event.srcElement ? event.srcElement : event.target; //FF只能识别event.target
 
2、event.fromElement、event.toElement
   
  1. <script language="javascript">
  2. //addEventListener是为一个事件添加一个监听,使用方法见http://cindylu520.iteye.com/admin/blogs/588652
  3. //此处if判断是否是火狐浏览器
  4. if(window.addEventListener) { FixPrototypeForGecko(); }
  5. function  FixPrototypeForGecko()
  6. {
  7. //prototype属性允许你向一个对象添加属性和方法
  8. //__defineGetter__和__defineSetter__是Firefox的特有方法,可以利用来它自定义对象的方法。
  9. //使用方法见:http://cindylu520.iteye.com/admin/blogs/588667
  10. //runtimeStyle   运行时的样式!如果与style的属性重叠,将覆盖style的属性!
  11. HTMLElement.prototype.__defineGetter__("runtimeStyle",element_prototype_get_runtimeStyle);
  12. //代表事件状态,如事件发生的元素,键盘状态,鼠标位置和鼠标按钮状态。
  13. window.constructor.prototype.__defineGetter__("event",window_prototype_get_event);
  14. //event.srcElement当前事件的源,IE下,event对象有srcElement属性,但是没有target属性;Firefox下,event对象有target属性,但是没有srcElement属性.但他们的作用是相当的
  15. Event.prototype.__defineGetter__("srcElement",event_prototype_get_srcElement);
  16. //当前事件有移动成分时,如onmouseover、onmouseout等fromElement、toElement表示移动事件的两个端点
  17. Event.prototype.__defineGetter__("fromElement",  element_prototype_get_fromElement);
  18. Event.prototype.__defineGetter__("toElement", element_prototype_get_toElement);
  19. }
  20. function  element_prototype_get_runtimeStyle() { return  this.style; }
  21. function  window_prototype_get_event() { return  SearchEvent(); }
  22. function  event_prototype_get_srcElement() { return  this.target; }
  23. function element_prototype_get_fromElement() {
  24. var node;
  25. //relatedTarget 事件属性返回与事件的目标节点相关的节点。
  26. //对于 mouseover 事件来说,该属性是鼠标指针移到目标节点上时所离开的那个节点。
  27. //对于 mouseout 事件来说,该属性是离开目标时,鼠标指针进入的节点。
  28. //对于其他类型的事件来说,这个属性没有用。
  29. //详情:http://cindylu520.iteye.com/admin/blogs/588678
  30. if(this.type == "mouseover") node = this.relatedTarget;
  31. else if (this.type == "mouseout") node = this.target;
  32. if(!node) return;
  33. while (node.nodeType != 1)
  34. node = node.parentNode;
  35. return node;
  36. }
  37. function  element_prototype_get_toElement() {
  38. var node;
  39. if(this.type == "mouseout")  node = this.relatedTarget;
  40. else if (this.type == "mouseover") node = this.target;
  41. if(!node) return;
  42. while (node.nodeType != 1)
  43. node = node.parentNode;
  44. return node;
  45. }
  46. function  SearchEvent()
  47. {
  48. if(document.all) return  window.event;
  49. func = SearchEvent.caller;
  50. while(func!=null){
  51. var  arg0=func.arguments[0];
  52. if(arg0 instanceof Event) {
  53. return  arg0;
  54. }
  55. func=func.caller;
  56. }
  57. return   null;
  58. }
  59. </script>

好了,现在不管是在 IE 中还是在 FireFox 中,触发事件后都有了 event、event.srcElement、event.fromElement、event.toElement 属性了。这就来做个测试吧:

Java代码  
  1. <script>
  2. function test(){
  3. alert("event:" + event +", srcElement:"+event.srcElement.innerHTML+
  4. ", fromElement:"+event.fromElement.innerHTML + ", toElement:"+event.toElement.innerHTML)
  5. }
  6. </script>
  7. <button onmouseout="test()">MouseOut</button><button onmouseover="test()">MouseOver</button>

页面中有两个按钮 MouseOut 和 MouseOver,你掠过第一个按钮到第二个按钮上是,有看到这样内容的窗口:

从上图可以看出,其实我是在 Google 的 Chrome 浏览器中作的测试,也是有效的。标题虽说是兼容 IE 和 FireFox,但宽松点说就是 IE  和非 IE,因为 IE 总喜欢剑起偏锋,不按规范办事,不过这种事在 IE 8 中是收敛了许多。

event.srcElement ,event.fromElement,event.toElement的更多相关文章

  1. Javascript中event.srcElement和event.target的区别

    event.srcElement 可以捕获当前事件作用的对象,如event.srcElement.tagName可以捕获活动标记名称.注意获取的标记都以大写表示,如"TD",&qu ...

  2. js的event.srcElement与event.target(触发事件对象)

    IE下,event对象有srcElement属性,但是没有target属性; Firefox下,event对象有target属性,但是没有srcElement属性.但他们的作用是相当的,即: fire ...

  3. event.srcElement 用法笔记e.target

    event.srcElement 可以捕获当前事件作用的对象,如event.srcElement.tagName可以捕获活动标记名称. 注意获取的标记都以大写表示,如"TD",&q ...

  4. event.srcElement兼容处理

    在IE下,event对象有srcElement属性,但是没有target属性:Firefox下,even对象有target属性,但是没有srcElement属性.. 解决方法:使用obj(obj = ...

  5. event.srcElement与event.target的区别

    window.event.srcElement与window.event.target 都是指向触发事件的元素,它是什么就有什么样的属性 srcElement是事件初始化目标html元素对象引用,因为 ...

  6. 浏览器中event.srcElement和event.target的兼容性问题

    在IE下,event对象有srcElement属性,但是没有target属性:Firefox下,even对象有target属性,但是没有srcElement属性.. 解决方法:使用obj(obj = ...

  7. e.target和e.event和event.srcElement

    e.target 是目标对象,e.event是目标所发生的事件,event.srcElement捕获当前事件作用的对象 1. $(function(){ $("li:has(ul)" ...

  8. JS基础篇--JS的event.srcElement与event.target(触发事件对象)

    IE下,event对象有srcElement属性,但是没有target属性; Firefox下,event对象有target属性,但是没有srcElement属性.但他们的作用是相当的,即: fire ...

  9. window.event.srcElement与window.event.target 触发事件的元素 触发事件对象的获取,window.event与时间函数参数的event是同一个 事件对象

    判断事件触发的元素:     var tag = window.event.target || window.event.srcElement;    if (tag.tagName.toLowerC ...

随机推荐

  1. 能力素质模型咨询工具(Part1)

          之前写过由企业家基本素质想到的文章,里面提及一些能力与素质,以下有内容也可以参考: 领导职位 表6-1 远见卓识的行为表现 级 别 行 为 表 现 A (1)关注行业的前景和环境的变化, ...

  2. 关于C#消息调度(作业日志)

    在Windows定时作业中,其实有多种关于作业调度形式,比如Windows Services 和 Windows Form 都可以做到,各有各的好处.现在来介绍下使用插件的形式进行定时作业. 1.用q ...

  3. SharePoint 2013 Word 转换PDF服务介绍及示例

    前言:在SharePoint使用过程中,经常会发现将文档进行格式转换的需求,之前,看到SharePoint 2013有将PPT转换PDF文档的服务,后来,才发现SharePoint 2010开始,就有 ...

  4. Android 更新UI的几种方式

    1.Activity的 runOnUiThread textView = (TextView) findViewById( R.id.tv ); new Thread(new Runnable() { ...

  5. SJPullDownMenu下拉菜单框架使用

    SJPullDownMenu 快速集成类似淘宝筛选下拉菜单 如果页面显示不全等问题请转至:http://www.jianshu.com/p/d07c6393830c 查看使用 Getting Star ...

  6. React Native 红屏之Could not connect to development server.

    React Native 是目前最火的开发框架,其他不说了,上Bug. 按照  React Native iOS环境搭建 高级版 在mac上  搭建 React Native  环境,运行 项目 若出 ...

  7. [转]oracle 实施方法论学习心得

      本周由部门新入职的同事为我们分享oracle实施方法论,本次重点围绕项目启动会来做介绍,并着重介绍了oracle与我们不一样的地方.收获颇丰,简单总结几个值得学习借鉴的要点: 1.      细节 ...

  8. ORACLE表空间管理维护

    1:表空间概念 在ORACLE数据库中,所有数据从逻辑结构上看都是存放在表空间当中,当然表空间下还有段.区.块等逻辑结构.从物理结构上看是放在数据文件中.一个表空间可由多个数据文件组成. 如下图所示, ...

  9. Android:使用代理服务器安装SDKs

    在使用Android SDK Manager来安装SDK时,因为google的ip被墙了,所以下载文件时,下载不到. 面对不能访问google的问题,通常有下列方案: 1)修改hosts文件,需要有正 ...

  10. 【hive】——metastore的三种模式

    Hive中metastore(元数据存储)的三种方式: 内嵌Derby方式 Local方式 Remote方式 [一].内嵌Derby方式 这个是Hive默认的启动模式,一般用于单元测试,这种存储方式有 ...