监听H5页面在微信浏览器异常退出

参考文章

js 复制代码
onBeforeUnmount(() => {
  unNormalExit();
});

//---------------------------异常退出----------------------
function unNormalExit() {
  enterOrExitRoom({
    type: 37,
    roomId: roomId.value,
    userId: userId.value,
    nickName: name.value,
    loginUserType: 2, //0 专家 1员工 2第三方 app登录类型
  }).then(async (res) => {
    await trtc.exitRoom();
    await trtc.stopLocalVideo();
    await trtc.stopLocalAudio();
    // 若后续无需再使用该 trtc,则销毁 trtc,并释放引用。
    trtc.destroy();
  });
  closeWebSocketH5();
}

// 微信浏览器
// ios 的 window.addEventListener("pagehide", function () {}  监听方法内,
// 不支持 ajax,需要通过 navigator.sendBeacon("url",data) 来调后台接口。
if (deviceType == "Android") {
  if (window.addEventListener) {
    document.addEventListener("visibilitychange", async function () {
      //部分手机可以获取到
      if (document.hidden) {
        //用户关闭了安卓页面
        //做关闭页面处理逻辑
        unNormalExit();
      }
    });
  } else if (window.attachEvent) {
    // 主要是为了兼容老的IE
    window.attachEvent("onpagehide", async function () {
      unNormalExit();
    });
  } else {
    window.onbeforeunload = async function () {
      unNormalExit();
    };
  }
} else {
  //苹果:有时会执行closeWebSocket,有时不会,让后台监听心跳断开之后主动调用一次退出
  window.addEventListener(
    "pagehide",
    function () {
      closeWebSocketH5();
      unNormalExit();
      // let data = new Blob(
      //   [JSON.stringify({ gameId: gameId, userId: userid })],
      //   {
      //     type: "application/json; charset=UTF-8",
      //   }
      // );
      // navigator.sendBeacon("/destory", data);
    },
    false
  );
}
相关推荐
扛麻袋的少年15 小时前
7.Kotlin的日期类
开发语言·微信·kotlin
JohnYan7 天前
工作笔记 - 一次微信认证集成迁移
后端·安全·微信
摸着石头过河的石头8 天前
微信h5页面开发遇到的坑
前端·微信
悟空码字11 天前
老婆说要是能做个育儿补贴计算小程序就生二胎?用腾讯云代码助手CodeBuddy立马手戳了一个
微信
阿彬爱学习12 天前
AI 大模型企业级应用落地挑战与解决方案
人工智能·算法·微信·chatgpt·开源
王小发10114 天前
怎么打败微信内置浏览器的恐怖缓存
前端·微信
qq_256847888616 天前
oelove奥壹新版v11.7旗舰版婚恋系统微信原生小程序源码上架容易遇到的几个坑,避免遗漏参数白屏显示等问题
微信·奥壹原生小程序源码·奥壹婚恋交友系统小程序·oelove婚恋交友小程序源码·婚恋交友开源版·奥壹小程序上架设置
gongzemin23 天前
微信第三方平台的配置
微信·微信小程序·资讯
劫大大24 天前
前端开发公众号或服务号,本地怎么与后端测试服接口打通呢
前端·微信
追逐时光者1 个月前
推荐 2 款简洁美观的微信公众号 Markdown 编辑器,让你不再为微信内容排版而发愁!
微信