当前位置: 首页 > news >正文

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

http://www.cnnetsun.cn/news/144716.html

相关文章:

  • Node.js body-parser终极使用指南:从基础到高级应用
  • 如何安全地通过WiFi远程控制Android设备?Open-AutoGLM权威配置指南来了
  • 高速接口防护:低电容与信号完整性权衡-ASIM阿赛姆
  • 【开发者必备工具】Windows 11 安装 Git 完整指南
  • 中兴调制解调器工具完整配置手册:5步开启高级管理功能
  • Pydantic与Logfire集成实战:构建可观测的数据验证系统
  • 库早报|国内首例!全3D打印涡扇发动机试车成功;科锐智能SLS设备众筹上线;中国极地研究中心采购光固化机器
  • 如何在内网环境运行Open-AutoGLM?离线部署终极解决方案
  • 高效获取气体数据:科研与工业应用的终极指南
  • iOS 16.7设备支持包:解决Xcode调试难题的完整指南
  • 【AI本地化新突破】:Open-AutoGLM在Windows 11的3种部署方式大公开
  • 云原生网关Higress与Istio深度整合:构建端到端流量治理体系的完整指南
  • UI-TARS坐标定位精度优化:从像素偏差到亚像素精度的技术演进
  • Alpine Node.js Docker镜像终极指南:构建轻量级应用容器
  • LabelImg标注质量实战:从IOU计算到一致性检查的避坑指南
  • FaceFusion在智能门禁系统中的活体检测扩展应用
  • Bazel模块扩展实战:从依赖管理到构建生态的完整解决方案
  • Windows7系统必备:KB2999226补丁全面解析与安装指南
  • ControlNet终极指南:5个黄金法则实现AI绘画的精确控制
  • 网页设计模板网站 企业政务网页设计模板-专业的企业网站建设方案
  • Gboard词库Magisk模块:终极输入体验提升指南
  • 深入浅出现代C++内存模型
  • 如何从零部署eRPC:3步完成高性能RPC库配置
  • Sublime Text Markdown预览插件:让文档编写更高效
  • Stable Diffusion 3.5 FP8 多领域应用案例深度解析
  • 移动端AI模型部署实战:从性能瓶颈到极速推理的完整解决方案
  • Noi浏览器与豆包AI深度整合:一站式智能助手解决方案
  • 还在等官方API?现在就能本地运行AutoGLM-Phone-9B,完整安装流程曝光
  • 1、在 Mac 上运行 Windows:解锁新的计算可能性
  • 7、VMware Fusion:安装与使用指南