为什么前端监控要用 GIF 打点/埋点

发布于 2024-12-11 12:39:38 字数 1518 浏览 9 评论 0

目前主流的前端监控数据上报都是采用 GIF 的上报方式,(百度统计/友盟/谷歌统计)都是这样实现的。但为什么一定要使用 GIF 呢?不能发 post 请求或者通过 script 标签的形式么?

当然你也可以使用一些黑科技的方式上报,用纯 css 来实现。但这种方案并没有什么特别的好处。

.track-xx:active:after {
  content: url(track.php?xxxx=foo);
}

主要原因

  • 没有跨域问题
  • 不会阻塞页面加载,影响用户体验
  • 在所有图片中体积最小,相较 BMP/PNG,可以节约 41%/35%的网络资源

详情见 为什么前端监控要用 GIF 打点

使用方式

但建议不要按如下方法使用

new Image().src = 'https://foo.com/bar.gif?t=xxxx&b=1' 

这段代码的问题是这个 new Image() 是一个没有引用的临时变量,随时可能被浏览器的垃圾回收机制回收。如果这个图片的 HTTP 请求尚未建立,那么在被回收时这个请求就会被取消,导致打点并没有真正发出。如果打点所在的页面比较复杂,浏览器垃圾回收机制可能会被频繁触发,那么这种方式打点的丢失率可能会高达 10%以上。

解决方法很简单,将这个图片赋值给一个全局变量即可,例如:

const img = new Image()
const key = +new Date() //加一个时间戳,防止图片被浏览器缓存了,不再发送请求

window[t] = img

img.onload = img.onerror = img.onabort = function() {
  // img 标签加载完成、错误或终止时,解除事件绑定,销毁相关对象
  img.onload = img.onerror = img.onabort = null
  window[key] = null
  img = null
}
img.src = `${url}?t=key`

其它方案

Beacon API

  • 在空闲的时候异步发送统计,不影响页面诸如 JS、CSS Animation 等执行
  • 即使页面在 unload 状态下,也会异步发送统计,不影响页面过渡/跳转到下跳页
  • 能够被客户端优化发送,尤其在 Mobile 环境下,可以将 Beacon 请求合并到其他请求上,一同处理

navigator.sendBeacon("/log", analyticsData);

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

文章
评论
24 人气
更多

推荐作者

最终幸福

文章 0 评论 0

与酒说心事

文章 0 评论 0

┈┾☆殇

文章 0 评论 0

梦醒灬来后我

文章 0 评论 0

念﹏祤嫣

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文