离开网页弹窗函数onbeforeunload与onunload

在编辑中,一不小关闭了浏览器,把自己辛辛苦苦编辑过的内容都丢失了,这个一个很苦恼的事情,onbeforeunload可以在离开页面时出发一个对话框,提示用户是否要关闭页面。

onbeforeunload

onbeforeunload 事件在即将离开当前页面(刷新或关闭)时触发。 该事件可用于弹出对话框,提示用户是继续浏览页面还是离开当前页面。 对话框默认的提示信息根据不同的浏览器有所不同,标准的信息类似 "确定要离开此页吗?"。该信息不能删除。 但你可以自定义一些消息提示与标准信息一起显示在对话框。 注意: 如果你没有在 <body> 元素上指定 onbeforeunload 事件,则需要在 window 对象上添加事件,并使用 returnValue 属性创建自定义信息(查看以下语法实例)。 注意: 在 Firefox 浏览器中,只显示默认提醒信息(不显示自定义信息)。 使用方法:
window.onbeforeunload=function(){
	return "你确定要离开吗";
}
事件触发的时候弹出一个有确定和取消的对话框,确定则离开页面,取消则继续待在本页。当然你可以自定义提示文本。 那么,当我只需要在我离开时执行这个函数,而刷新的时候不执行,那怎么做呢?
 window.onbeforeunload = function() {

	    var n = window.event.screenX - window.screenLeft;

	    var b = n > document.documentElement.scrollWidth - 20;

	    if (!(b && window.event.clientY < 0 || window.event.altKey)) {
	        //window.event.returnValue = "真的要刷新页面么?"; 
	        
	         //这里放置我想执行缓存的代码
	         cacheFunction();
	        
	    }
  } 
这样,我离开页面时,可以执行我的缓存代码,而不弹出提示框,我刷新时也不弹出提示框,也不执行。值得一提的时,这个时候,要将ajax设置为同步,即:ajax里面的 async改为: false; 浏览器兼容情况 IE、Chrome、Safari 完美支持 Firefox 不支持文字提醒信息 Opera 不支持

onunload

onunload 事件在用户退出页面时发生。 使用方法和onbeforeunload类似
window.onunload = function(){
   return "你确定要离开吗"
}
浏览器兼容情况 IE6,IE7,IE8 中 刷新页面、关闭浏览器之后、页面跳转之后都会执行; IE9 刷新页面 会执行,页面跳转、关闭浏览器不能执行; firefox(包括firefox3.6) 关闭标签之后、页面跳转之后、刷新页面之后能执行,但关闭浏览器不能执行; Safari 刷新页面、页面跳转之后会执行,但关闭浏览器不能执行; Opera、Chrome 任何情况都不执行。