• 如何使用和关闭onbeforeunload 默认的浏览器弹窗事件


    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 = '您正在学习中,继续此操作将不记录学时,保留学时请签退!';
        };
    }
    

     

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

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

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

      

     

  • 相关阅读:
    1592:【例 1】国王
    状态压缩类动态规划笔记
    1300:鸡蛋的硬度
    1263:【例9.7】友好城市
    第四部分-并发编程案例分析4:高性能数据库连接池HikariCP
    容器基础3:容器镜像
    第四部分-并发编程案例分析3:高性能队列Disruptor
    容器基础2:隔离与限制
    第四部分-并发编程案例分析1:限流Guava RateLimiter
    容器基础1:进程
  • 原文地址:https://www.cnblogs.com/yesu/p/7207134.html
Copyright © 2020-2023  润新知