利用jQuery的$.event.fix函数统一浏览器event处理

 

做WEB前端开发的人都知道不同的浏览器对事件的处理方式是有区别的,比如得到触发事件的元素引用在IE浏览器下是:event.srcElement,在FF浏览器下则是:event.target,另外又比如在FF浏览器下得到光标相对页面的位置是event.pageX,而IE浏览器下的处理方式又是不一样的,当然还有一些像“阻止事件冒泡”以及“取消浏览器默认行为”等,不同浏览器也有不同的处理方式,如果我们要使JavaScript在不同的浏览器下能正常处理事件代码,就要分别进行判断处理。现在jQuery为我们提供了统一兼容处理函数$.event.fix(e),这个函数官方并没有在文档中说明用法,是我在阅读框架代码的时候发现可以这样使用。

一、如何使用

使用jQuery的event兼容处理主要分以下几个简单步骤进行:

1、在网页head区引用jQuery框架库文件;
2、定义一个事件处理方法,在调用的地方统一传入event参数;
3、在事件方法内部首先利用$.event.fix把旧的事件转换成新的事件引用;
4、在事件方法后面使用经过兼容处理后的事件对象方法和属性。

二、使用示例

<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
< html  xmlns ="http://www.w3.org/1999/xhtml" >
< head >
< meta  http-equiv ="Content-Type"  content ="text/html; charset=utf-8"   />
< title > 利用jQuery的$.event.fix函数统一浏览器event处理 </ title >
< script  type ="text/javascript"  src ="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js" ></ script >
</ head >

< body >
< input  type ="button"  value ="http://blog.csdn.net/webflash"  onclick ="eventHandler(event)"   />
< script  type ="text/javascript" >
// 请使用不同浏览器测试本页,你将看到一样的结果
function  eventHandler(e)
{
    
var  event  =  $.event.fix(e);
    
    
var  elem  =  event.target;
    alert(
' 当前点击对象的标签名是: '   +  elem.tagName);
    alert(
' 当前点击按钮文本是: '   +  elem.value);
    alert(
' pageX: '   +  event.pageX  +   ' ,pageY: '   +  event.pageY);
    
    
// 得到按键码
    event.keyCode
    
// 取消浏览器默认行为
    event.preventDefault();
    
// 取消事件冒泡
    event.stopPropagation();
    
    
// ...还有好些不是很常用属性,这里不一一列举
}
</ script >
</ body >
</ html >

你可能感兴趣的:(jquery)