自然,我们都习惯了 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. zookeeper集群

    0,Zookeeper基本原理 ZooKeeper集群由一组Server节点组成,这一组Server节点中存在一个角色为Leader的节点,其他节点都为Follower.当客户端Client连接到Zo ...

  2. 推荐15个最好用的 JavaScript 代码压缩工具

    JavaScript 代码压缩是指去除源代码里的所有不必要的字符,而不改变其功能的过程.这些不必要的字符通常包括空格字符,换行字符,注释以及块分隔符等用来增加可读性的代码,但并不需要它来执行. 在这篇 ...

  3. 无限级ddsmoothmenu菜单实例

    点击这里查看效果以横向ddsmoothmenu下来菜单为例,以下是实现代码: <base target="_blank" /><link rel="st ...

  4. linux下安装MySQL出错file /usr/share/mysql/charsets/latin2.xml from install of MySQL-......

    linux64 red hat 6.3企业版 开始错误装了32位mysql最后怎么也装不上64mysql了,折腾了一番最后全部卸载搞定: file /etc/init.d/mysql from ins ...

  5. hibernate(2) —— 主键策略

    框架提供了三种主键生成方式,一种是由用户自己维护,一种是由hibernate框架维护,另一种是由数据库维护. 自己维护就是在插入数据的时候,一定要指定主键的值,否则会出错,如果由框架维护和由数据库维护 ...

  6. Java泛型介绍——HashMap总结

    今天在编程中,需要使用到Hashmap来存储和传递数据,发现自己学习Java这么久,实际上对泛型依旧知之甚少,搜索整理了一下HashMap的使用. HashMap的声明初始化,因为泛型的原因,起两个参 ...

  7. SharePoint 2013 Search 配置总结

    前言:SharePoint 2013集成了Fast搜索以后,搜索的配置有了些许改变,自己在配置过程中,也记录下了一些入门的东西,希望能够对大家有所帮助. 1.配置搜索服务,首先需要启用搜索功能,基本思 ...

  8. Linux学习心得之 linux命令

    作者:枫雪庭 出处:http://www.cnblogs.com/FengXueTing-px/ 欢迎转载 前言 本篇博客是对 每日一linux命令(http://www.cnblogs.com/pe ...

  9. QuickFlow UI 控件之 NamedFormAttachment

    在开发自定义表单时,如果碰到需要按类别上传附件的情况,(比如流程附件分为草稿版,正式版,发布版),比较难处理,需要开发自定义字段控件来实现. QF最新版本(Build131124)提供了NamedFo ...

  10. iOS、Xcode监测键盘的显示和隐藏变化,并获得键盘高度,改变tableView的frame和偏移

    <pre name="code" class="objc"><pre name="code" class="ob ...