在IE和火狐下通用:
<script type="text/javascript">
function close(
evt) //author: sunlei
{
var isIE=document.all?true:false;
evt = evt ? evt :(window.event ? window.event : null);
if(isIE){//
IE浏览器
var n = evt.screenX - window.screenLeft;
var b = n > document.documentElement.scrollWidth-20;
if(b && evt.clientY<0 || evt.altKey){
alert("是关闭而非刷新");
}
else{
alert("是刷新而非关闭");
}
}
else{//
火狐浏览器
if(document.documentElement.scrollWidth!=0)
alert("是刷新而非关闭");
else
alert("是关闭而非刷新");
}
}
</script>
<body οnunlοad="close(
event);">
其中参数
event是一定要传进去的,因为在火狐下如果不传的话,它会报错:
window.event is not defined。当然,在IE下如果不传的话,是没有问题的。
不过细心的人会发现,其实在火狐下进行判断的时候根本没有用到
evt。其实把
evt传进去,只是为了保证浏览器不会报错,其实可以做如下修改,效果是一样的:
<script type="text/javascript">
function close(
) //author: sunlei
{
var isIE=document.all?true:false;
if(isIE){//
IE浏览器
var n =
window.event.screenX - window.screenLeft;
var b = n > document.documentElement.scrollWidth-20;
if(b &&
window.event.clientY<0 ||
window.event.altKey){
alert("是关闭而非刷新");
}else{
alert("是刷新而非关闭");
}
}
else{//
火狐浏览器
if(document.documentElement.scrollWidth!=0)
alert("是刷新而非关闭");
else
alert("是关闭而非刷新");
}
}
</script>
<body οnunlοad="close(
);">
用JS在IE和火狐下判断网页是刷新还是关闭
最新推荐文章于 2010-09-29 15:32:00 发布