会员
众包
新闻
博问
闪存
赞助商
HarmonyOS
Chat2DB
所有博客
当前博客
我的博客
我的园子
账号设置
会员中心
简洁模式
...
退出登录
注册
登录
devbar
博客园
首页
新随笔
联系
订阅
管理
格式化事件
/*
格式化事件,因为IE和其他浏览器下获取事件的方式不同并且事件的属性也不尽相同,通过此方法提供一个一致的事件
*/
EventUtil.formatEvent
=
function
(oEvent)
{
//
isIE和isWin引用到一个js文件,判断浏览器和操作系统类型
if
(isIE
&&
isWin)
{
oEvent.charCode
=
(oEvent.type
==
"
keypress
"
)
?
oEvent.keyCode :
0
;
//
IE只支持冒泡,不支持捕获
oEvent.eventPhase
=
2
;
oEvent.isChar
=
(oEvent.charCode
>
0
);
oEvent.pageX
=
oEvent.clientX
+
document.body.scrollLeft;
oEvent.pageY
=
oEvent.clientY
+
document.body.scrollTop;
//
阻止事件的默认行为
oEvent.preventDefault
=
function
()
{
this
.returnValue
=
false
;
}
;
//
将toElement,fromElement转化为标准的relatedTarget
if
(oEvent.type
==
"
mouseout
"
)
{
oEvent.relatedTarget
=
oEvent.toElement;
}
else
if
(oEvent.type
==
"
mouseover
"
)
{
oEvent.relatedTarget
=
oEvent.fromElement;
}
//
取消冒泡
oEvent.stopPropagation
=
function
()
{
this
.cancelBubble
=
true
;
}
;
oEvent.target
=
oEvent.srcElement;
//
添加事件发生时间属性,IE没有
oEvent.time
=
(
new
Date).getTime();
}
return
oEvent;
}
;
EventUtil.getEvent
=
function
()
{
if
(window.event)
{
//
格式化IE的事件
return
this
.formatEvent(window.event);
}
else
{
return
EventUtil.getEvent.caller.arguments[
0
];
}
}
;
posted @
2009-06-29 17:28
Devbar
阅读(
177
) 评论(
0
)
收藏
举报
刷新页面
返回顶部
公告