企业微信和页面离开事件

💡 前言

最近在开发中遇到了一个需求:在用户关闭浏览器时上报。然而在企业微信环境下却发现了一些意想不到的行为差异。本文将详细记录这次踩坑经历,希望能为遇到类似问题的开发者提供参考。

如果你有更好的方案也请告知我。


🎯 核心结论

经过详细测试,发现不同浏览器环境下的行为存在显著差异:

📱 企业微信浏览器

  • 刷新场景beforeunload 事件未触发unload 事件正常触发sendBeacon 可以发送

  • 关闭场景beforeunloadunload 事件均未触发sendBeacon 无法发送

🌐 Chrome & Safari 浏览器

  • 刷新/关闭场景beforeunloadunload 事件均正常触发sendBeacon 均可发送

⚠️ 注意:本测试仅在 Mac 环境下进行,Windows 环境下的表现可能有所不同。


🧪 测试代码

为了验证这个问题,我编写了以下测试代码:

🔗 在线演示CodeSandbox

html 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
  </head>
  <body>
    <div id="nowTime"></div>
    <div id="beforeUnloadTime"></div>
    <div id="unloadTime"></div>
    <script>
      document.querySelector("#nowTime").innerHTML = "nowTime " + new Date();
      document.querySelector("#beforeUnloadTime").innerHTML =
        "beforeunloadTime " + localStorage.getItem("beforeunloadTime");
      document.querySelector("#unloadTime").innerHTML =
        "unloadTime " + localStorage.getItem("unloadTime");

      window.addEventListener("beforeunload", (event) => {
        localStorage.setItem("beforeunloadTime", "" + new Date());
        navigator.sendBeacon("/api/beforeunload/sendBeacon");
      });
      window.addEventListener("unload", (event) => {
        localStorage.setItem("unloadTime", "" + new Date());
        navigator.sendBeacon("/api/unload/sendBeacon");
      });
    </script>
  </body>
</html>

📊 详细测试结果

🏢 企业微信环境测试

🔄 刷新场景

  • 事件触发情况 :仅 unload 事件触发,beforeunload 事件失效
  • 网络请求情况 :仅 unload 中的 sendBeacon 成功发送

❌ 关闭场景

  • 事件触发情况beforeunloadunload 事件均未触发
  • 网络请求情况 :无任何 sendBeacon 请求发出

🌐 Chrome 浏览器测试

🔄 刷新场景

  • 事件触发情况beforeunloadunload 事件均正常触发
  • 网络请求情况 :两个 sendBeacon 请求均成功发送

❌ 关闭场景

  • 事件触发情况beforeunloadunload 事件均正常触发
  • 网络请求情况 :两个 sendBeacon 请求均成功发送

🧭 Safari 浏览器测试

🔄 刷新场景

  • 事件触发情况beforeunloadunload 事件均正常触发
  • 网络请求情况 :两个 sendBeacon 请求均成功发送

❌ 关闭场景

  • 事件触发情况beforeunloadunload 事件均正常触发
  • 网络请求情况 :两个 sendBeacon 请求均成功发送

🔧 测试环境配置

📋 测试环境说明

  • 操作系统:macOS(Windows 环境需要开发者自行验证)

  • 企业微信:基于 WKWebView 内核

  • 对比浏览器:Chrome、Safari 最新版本

🛠️ 企业微信调试模式开启方法

为了方便测试,可以开启企业微信的调试模式:

  1. 开启调试模式 :按下组合键 Ctrl + Option + Command + Shift + D

  2. 找到调试选项:在弹出的菜单中选择相应选项

  1. 使用调试窗口:会弹出一个专用的调试窗口,可以直接输入 URL 进行测试
相关推荐
不吃糖葫芦311 分钟前
vue3实现拓扑图编辑功能(谨以此纪念我当前的最后一份前端工作)
前端
大家的林语冰19 分钟前
超越 TypeScript,Flow 强势回归,语法高仿 TS,功能更丰富,类型更安全!
前端·javascript·typescript
এ慕ོ冬℘゜38 分钟前
jQuery 高可用多图上传组件(企业级封装 + 踩坑全解 + 可直接上线)
前端·javascript·jquery
爱勇宝44 分钟前
AI 时代,前端工程师的话语权正在下降?
前端·后端
kymjs张涛44 分钟前
一个月,纯VibeCoding,全平台云笔记APP
前端·javascript·后端
巴勒个啦1 小时前
esbuild 插件实战:5个真实场景带你自定义构建流水线
前端·angular.js
狗头大军之江苏分军1 小时前
前端路由是怎么来的
前端·javascript·后端
Patrick_Wilson1 小时前
Cookie 作用域避坑:父域泄漏、同名优先级与多环境隔离
前端·http·浏览器
api工厂1 小时前
ZCode 3.0 版本搭配GLM-5.2能力测试
前端·人工智能·ai