zoukankan      html  css  js  c++  java
  • 如何使用和关闭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) {
           
        };
    }
    

      

     

  • 相关阅读:
    sql server 的变量
    psycopg2 (python与postgresql)
    sublime text3 设置快速生成代码
    关于 Form 表单的 enctype 属性
    根据二进制流判断文件类型
    URL编码和Base64编码 (转)
    GZip 压缩及解压缩
    HttpWebRequest 请求 Api 及 异常处理
    c# BinaryWriter 和 BinaryReader
    JQ 上传文件(单个,多个,分片)
  • 原文地址:https://www.cnblogs.com/yesu/p/7207134.html
Copyright © 2011-2022 走看看