2020-02-11 vue 关闭窗体并利用navigator.

2020-02-11  本文已影响0人  追寻1989
export default { 
  data(){
        return{
           _beforeUnload_time:0,
           _gap_time:0,
        }
  },
  mounted() {
      //组件挂载时监听窗体关闭监听事件
      window.addEventListener("beforeunload", e => {
        this.beforeunloadHandler(e);
      });
      window.addEventListener('unload', e => this.unloadHandler(e))
  },
  destroyed() {
      //组件销毁时清除窗体监听事件
      window.removeEventListener("beforeunload", e => {
        this.beforeunloadHandler(e);
      });
      window.removeEventListener('unload', e => this.unloadHandler(e))
  },
  methods:{
    //判断是窗口关闭还是刷新
    unloadHandler(e){
      this._gap_time=new Date().getTime()-this._beforeUnload_time;
      if(this._gap_time<=5){
        //关闭要做的事情(这里可以发送请求,window.beforeunload事件在window.unload事件之前执行。同时注意ajax请求方式必须为同步请求,所以不能使用axios,因为axios不能执行同步请求,推荐使用navigator.sendBeacon。原因参考文章里有介绍)
      // 获取当前域名
      let protocolStr = window.location.protocol;
      let k_host = window.location.host;
      let path = protocolStr + "//" + k_host;
      //判断运行环境,设置跨域代理前缀
      if(process.env.NODE_ENV === 'development') {
        path =  '/api';
      }
       //发送需要的请求
        const res= navigator.sendBeacon(path+'/xxxxx/abc.jhtml', '') //sendBeacon 接收两个参数 navigator.sendBeacon(url, data); url 请求路径 data 请求参数 发送方式为POST,需要后端支持
       //由于关闭窗体无法控制台调试,借助本地存储查看发送结果,true发送成功,false发送失败
        if(exportEndRes){
          window.localStorage.setItem("isRquire",JSON.stringify(exportEndRes))
        }
      }else{
        //刷新要做的事情...
      }
    }
    /**
     * [beforeunloadHandler 浏览器关闭时进行用户提示]
     * @return {[type]} [description]
     */
    beforeunloadHandler(e) {
      this._beforeUnload_time=new Date().getTime();
    }
  }
 }
}

参考文献:

1.Vue中关闭浏览器不会触发onbeforeunload 无效

2.sendBeacon 刷新/关闭页面之前发送请求

上一篇 下一篇

猜你喜欢

热点阅读