为什么前端监控要用 GIF 打点/埋点
目前主流的前端监控数据上报都是采用 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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论