<script language=javascript>
function window.onbeforeunload()
{
if(event.clientX>document.body.clientWidth&&event.clientY<0||event.altKey||event.ctrlKey)
{
//判斷event.altKey是為了Alt+F4關閉的情況;判斷event.ctrlKey是為了Ctrl+W關閉的情況
//document.body.clientWidth不包括捲軸,而關閉按鈕恰好在捲軸右側。
window.event.returnValue="";
}
}
</script>
1、瀏覽器不是軟體的視窗,要該事件非常困難,因為關閉與重新整理這兩個事件就很難區分。
2、都沒有對應的事件,只能根據一些條件來判斷,但未必準確。
3、前進、後退、重新整理、關閉都響應事件window.onbeforeunload。
4、javascript之所以能得到某些事件屬性和調用方法,是因為瀏覽器對象為他提供了介面,用COM的術語來說,是IDispatch介面,如果瀏覽器對象沒有為他提供介面,他什麼也幹不了。所以有些功能在其它語言中可以實現,而在javascript中是永遠無法實現的。
用onUnload方法
在body 標籤裡加入onUnload事件
body onUnload="myClose()"
然後在javascript裡定義myClose()方法,但是onUnload方法是在關閉視窗之後執行,不是在關閉視窗之前執行,如果你想在關閉視窗之前做判斷,請用第一種方法
function getEvent() //同時相容ie和ff的寫法, 這個方法是網上copy的
{
if(document.all) return window.event;
func=getEvent.caller;
while(func!=null){
var arg0=func.arguments[0];
if(arg0)
{
if((arg0.constructor==Event || arg0.constructor ==MouseEvent)
|| (typeof(arg0)=="object" && arg0.preventDefault && arg0.stopPropagation))
{
return arg0;
}
}
func=func.caller;
}
return null;
}
function ConfirmClose(){
if(window.event){
window.event.returnValue = "在關閉視窗前確認您是否已經儲存了資訊!";
}else{
getEvent().preventDefault();//for firefox
}
}
function on_page_loaded(){//自己定義的body的onload事件
try{
if(!window.onbeforeunload){ //為了不覆蓋原來的onbeforeunload方法,先判斷
window.onbeforeunload = ConfirmClose; //todo 增加了視窗關閉前的提示
}
}catch(e){}
}
<body onload="on_page_loaded()">
//開啟表單應先判斷父表單是否關閉
function rsSeek(){
if(opener){
if(typeof(window.opener.document)=='unknown' ||typeof(window.opener.document) == 'undefined'){
//已關閉
}else{
opener.MySeekOk();
}
}
}