news 2026/6/23 19:11:16

navigator.sendBeacon方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
navigator.sendBeacon方法

navigator.sendBeacon() 是现代浏览器提供的一个 API,用于在页面卸载(如关闭标签页、导航到其他页面)时,异步且可靠地向服务器发送少量数据(如日志、分析数据等)。它解决了传统 XMLHttpRequest 或 fetch 在页面卸载时可能因浏览器终止任务而失败的问题。

1. 核心特性

  • 异步发送
    • 数据发送不会阻塞页面卸载流程,适合在 beforeunload、unload 等事件中发送数据。
  • 可靠性
    • 浏览器会确保数据在后台发送,即使页面已卸载也会尝试完成传输(除非浏览器被强制关闭)。
  • 轻量级
    • 仅支持发送少量数据(通常限制为几 KB),格式为 Blob、FormData、ArrayBuffer 或字符串。
  • 无响应处理
    • 该方法返回 boolean,表示浏览器是否接受请求,但不会返回服务器响应(设计初衷是单向通信)。

2. 语法

constsuccess=navigator.sendBeacon(url,data);
  • url:目标服务器地址(必须同源或支持 CORS)。
  • data:要发送的数据(可选),可以是 Blob、FormData、ArrayBuffer 或字符串。
  • 返回值:true 表示浏览器已接受请求,false 表示失败(如数据过大或浏览器不支持)。

3. 使用场景

  1. 页面关闭时发送分析数据
    例如记录用户停留时间、最后操作等:
    window.addEventListener('beforeunload',()=>{constdata=JSON.stringify({event:'page_close',time:Date.now()});navigator.sendBeacon('/analytics',data);});
  2. 提交表单数据
    在卸载前发送用户输入(需配合 FormData):
    constformData=newFormData();formData.append('feedback','User comment...');navigator.sendBeacon('/submit',formData);

4. 注意事项

  1. 数据大小限制
    不同浏览器限制不同(通常 64KB 左右),超限会返回 false。
  2. CORS 配置
    目标 URL 需支持 CORS(尤其是跨域请求时)。
  3. 无回调机制
    如需确认服务器是否收到数据,需通过其他方式(如后续请求或 WebSocket)。
  4. 兼容性
    现代浏览器均支持,但旧版 IE 不兼容(可用 navigator.sendBeacon 存在性检测)。

5. 与替代方案对比

方法阻塞页面卸载可靠性数据大小适用场景
sendBeacon❌ 不阻塞✅ 高页面卸载时发送数据
fetch/XMLHttpRequest✅ 阻塞❌ 低实时交互(如 AJAX)
Image 对象❌ 不阻塞❌ 低简单跟踪(如埋点)

示例代码

// 发送 JSON 数据constdata=newBlob([JSON.stringify({key:'value'})],{type:'application/json'});constsuccess=navigator.sendBeacon('https://example.com/log',data);if(success){console.log('Beacon queued successfully.');}else{console.error('Failed to send beacon (data too large or unsupported).');}

6. 总结

navigator.sendBeacon() 是处理页面卸载时数据上报的最佳实践,尤其适合日志、埋点等场景。它的异步非阻塞特性和高可靠性使其成为传统方法的理想替代方案。使用时需注意数据大小和兼容性,并避免依赖其响应结果。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 0:08:30

Node.js body-parser终极使用指南:从基础到高级应用

Node.js body-parser终极使用指南:从基础到高级应用 【免费下载链接】body-parser Node.js body parsing middleware 项目地址: https://gitcode.com/gh_mirrors/bo/body-parser body-parser是Node.js生态中最受欢迎的请求体解析中间件,专门用于处…

作者头像 李华
网站建设 2026/6/22 22:33:22

如何安全地通过WiFi远程控制Android设备?Open-AutoGLM权威配置指南来了

第一章:Open-AutoGLM远程控制架构概览Open-AutoGLM 是一种基于大语言模型(LLM)驱动的自动化远程控制系统,专为智能设备管理与跨平台任务编排设计。其核心架构融合了自然语言理解、指令解析、安全通信与执行反馈闭环,实…

作者头像 李华
网站建设 2026/6/22 21:47:51

高速接口防护:低电容与信号完整性权衡-ASIM阿赛姆

在USB4.0、HDMI 2.1、PCIe 5.0等超高速接口普及的今天,硬件工程师面临一个核心困境:如何在结电容<0.3pF的严苛要求下,实现8kV以上的ESD防护能力。低电容意味着信号失真小,但也意味着防护能力可能不足;高防护…

作者头像 李华
网站建设 2026/6/23 10:29:44

【开发者必备工具】Windows 11 安装 Git 完整指南

📝 适合人群:Git 初学者、Windows 11 用户 ⏱️ 预计时间:10-15 分钟 🎯 学习目标:成功在 Windows 11 上安装并配置 Git 📖 什么是 Git? Git 是一个分布式版本控制系统,简单来说&am…

作者头像 李华
网站建设 2026/6/23 6:50:32

中兴调制解调器工具完整配置手册:5步开启高级管理功能

中兴调制解调器工具完整配置手册:5步开启高级管理功能 【免费下载链接】zte_modem_tools 项目地址: https://gitcode.com/gh_mirrors/zt/zte_modem_tools 想要深度管理你的中兴调制解调器吗?这款开源工具集专为中兴设备设计,提供工厂…

作者头像 李华
网站建设 2026/6/16 1:31:21

Pydantic与Logfire集成实战:构建可观测的数据验证系统

Pydantic与Logfire集成实战:构建可观测的数据验证系统 【免费下载链接】pydantic Data validation using Python type hints 项目地址: https://gitcode.com/GitHub_Trending/py/pydantic 在当今数据驱动的应用开发中,数据验证的可靠性直接决定了…

作者头像 李华