宝塔服务器面板,一键全能部署及管理,送你10850元礼包,点我领取

Onunload,onbeforeunload都是在刷新或关闭时调用,可以在<script>脚本中通过 window.onunload来指定或者在<body>里指定。区别在于onbeforeunload在onunload之前执行,它还可 以阻止onunload的执行。

  Onbeforeunload也是在页面刷新或关闭时调用,Onbeforeunload是正要去服务器读 取新的页面时调用,此时还没开始读取;而onunload则已经从服务器上读到了需要加载的新的页面,在即将替换掉当前页面时调用。Onunload是无 法阻止页面的更新和关闭的。而 Onbeforeunload 可以做到。
触发于:
  ·关闭浏览器窗口 
  ·通过地址栏或收藏夹前往其他页面的时候 
  ·点击返回,前进,刷新,主页其中一个的时候 
  ·点击 一个前往其他页面的url连接的时候 
  ·调用以下任意一个事件的时候:click,document write,document open,document close,window close ,window navigate ,window NavigateAndFind,location replace,location reload,form submit. 
  ·当用window open打开一个页面,并把本页的window的名字传给要打开的页面的时候。 
  ·重新赋予location.href的值的时候。 
  ·通过input type=”submit”按钮提交一个具有指定action的表单的时候。 
  可以用在以下元素:
  ·BODY, FRAMESET, window

要想定制自己的一套浏览器关闭弹窗的内容,只需要在return 里面,return出来你需要的编写的内容即可。但是基本的框架的内容不会改变

window.onbeforeunload = function (e) {
        return (e || window.event).returnValue = '您正在学习中,继续此操作将不记录学时,保留学时请签退!';
    };
}

 如何使用和关闭onbeforeunload 默认的浏览器弹窗事件-风君雪科技博客

要是想关掉默认的浏览器的退出的弹窗,只需要在函数体什么都不写就可以了。

由此可见,除了在火狐下,其他的浏览器在弹出的确认框的时候都会显示你return的内容。如果你不写return的话,浏览器会判断你是一个undefined值或NULL,将不起作用(可以return undefined或者return null来实践,效果就是不写return。注:如果写return false的话也是会有效的,因为return到了一个值)。如果要让每个浏览器弹出的内容差不多的话,就return个空的字符串就好。

function testMothed(){
    window.location.href='index.html';
    window.onbeforeunload = function (e) {
       
    };
}