news 2026/5/8 19:29:24

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/5/1 23:43:18

5个步骤让你的系统监控工具从单调到惊艳的界面改造指南

还在忍受那些枯燥乏味的系统监控界面吗?想要让你的桌面监控既实用又美观?通过简单的配置调整,你可以将单调的系统监控工具打造成桌面的视觉亮点。本文将带你从零开始,通过Conky这款轻量级系统监控工具,实现从基础监控到…

作者头像 李华
网站建设 2026/5/3 11:51:56

Hyperf框架Swow集成技术架构分析与实践路径

Hyperf框架Swow集成技术架构分析与实践路径 【免费下载链接】hyperf 🚀 A coroutine framework that focuses on hyperspeed and flexibility. Building microservice or middleware with ease. 项目地址: https://gitcode.com/gh_mirrors/hy/hyperf 在PHP高…

作者头像 李华
网站建设 2026/5/7 23:55:18

USB3.0接口ESD二极管电容参数选择-ASIM阿赛姆

USB3.0接口凭借5Gbps的高速传输能力,已成为消费电子、工业设备、汽车电子的标准配置。然而,高速特性使其对ESD防护器件的寄生参数极度敏感。结电容过大直接导致眼图闭合、抖动超标、误码率激增;结电容过小又可能牺牲防护能力。据统计&#xf…

作者头像 李华
网站建设 2026/5/2 11:44:35

FaceFusion开源社区爆发增长,相关GPU算力需求翻倍

FaceFusion开源社区爆发增长,相关GPU算力需求翻倍 在短视频平台每秒生成数万条内容的今天,一个看似“小众”的AI换脸工具正悄然改变着数字创作的底层逻辑。FaceFusion——这个诞生于开源社区的人脸融合项目,已经从极客玩具演变为影视级视觉特…

作者头像 李华
网站建设 2026/4/28 5:09:11

基于Django的物流管理系统的设计与实现(源码+lw+远程部署)

目录: 博主介绍: 完整视频演示: 系统技术介绍: 后端Java介绍 前端框架Vue介绍 具体功能截图: 部分代码参考: Mysql表设计参考: 项目测试: 项目论文:​ 为…

作者头像 李华
网站建设 2026/5/8 17:02:05

FaceFusion模型热更新机制:不停机升级新版本

FaceFusion模型热更新机制:不停机升级新版本 在如今的AI内容生成浪潮中,人脸替换技术早已不再是实验室里的概念演示。从短视频平台的实时换脸特效,到影视工业级的后期合成,用户对“无缝体验”的要求越来越高——他们不关心后台用…

作者头像 李华